通過 Docker 搭建 Git 代碼審閱 Gitlab 代碼管理平臺

docker搭建私有代碼管理平臺 Gitlab

前言

  • 簡單記錄下各種網(wǎng)上資料搭建完gitlab下的步驟,給自己做個小筆記......
搭建 Docker 環(huán)境(centos環(huán)境)
#查看你當(dāng)前的內(nèi)核版本
uname -r

#安裝 Docker
yum -y install docker-io

#啟動 Docker 后臺服務(wù)
service docker start

#查看Docker的版本
docker version

#輸出如下安裝成功
Client:
 Version:         1.13.1
 API version:     1.26
 Package version: docker-1.13.1-68.gitdded712.el7.centos.x86_64
 Go version:      go1.9.4
 Git commit:      dded712/1.13.1
 Built:           Tue Jul 17 18:34:48 2018
 OS/Arch:         linux/amd64

Server:
 Version:         1.13.1
 API version:     1.26 (minimum version 1.12)
 Package version: docker-1.13.1-68.gitdded712.el7.centos.x86_64
 Go version:      go1.9.4
 Git commit:      dded712/1.13.1
 Built:           Tue Jul 17 18:34:48 2018
 OS/Arch:         linux/amd64
 Experimental:    false

#docker 常用命令
docker images     #查看鏡像
docker rmi  CONTAINER ID      #刪除止該Id鏡像(需刪除鏡像相關(guān)容器才可刪除)
docker ps -a      #容器查看
docker stop  CONTAINER ID    #停止該Id容器
docker rm  CONTAINER ID      #刪除止該Id容器
安裝 gitlab
#拉取Gitlab-ce鏡像
sudo docker pull gitlab/gitlab-ce:latest

#創(chuàng)建容器
sudo docker run --detach \
    --hostname gitlab.example.com \
    --publish 8443:443 --publish 8087:80 --publish 2222:22 \
    --privileged=true \
    --name gitlab \
    --restart always \
    --volume /home/gitlab/config:/etc/gitlab \
    --volume /home/gitlab/logs:/var/log/gitlab \
    --volume /home/gitlab/data:/var/opt/gitlab \
    gitlab/gitlab-ce:latest
    
#創(chuàng)建容器說明
--hostname    # 指定容器域名(gitlab.example.com ),未知功能:創(chuàng)建鏡像倉庫的時候使用到
--publish     # 將容器內(nèi)443端口映射到主機(jī)8443,提供https服務(wù)
              # 將容器內(nèi)80端口映射到主機(jī)8087,提供http服務(wù)
              # 將容器內(nèi)22端口映射到主機(jī)2222,提供ssh服務(wù)
--name        # 指定容器名稱
--restart     # 容器退出時,自動重啟
--volume      # 將本地/home/gitlab/config掛載到容器內(nèi)/etc/gitlab
--volume      # 將本地/home/gitlab/logs掛載到容器內(nèi)/var/log/gitlab
--volume      # 將本地/home/gitlab/data掛載到容器內(nèi)/var/opt/gitlab
gitlab        # 鏡像名稱:版本

#查看Gitlab容器運行情況
docker inspect gitlab --format "{{.State.Status}}"

輸出 running 表示運行正常
日記分析
'如果狀態(tài)為restaring,解決方案如下:'
#查看日記文件,根據(jù)日記解決
docker logs [容器名/容器ID]

#或者
docker logs -f -t --since="2018-08-10" --tail=10 gitlab

--since : 此參數(shù)指定了輸出日志開始日期,即只輸出指定日期之后的日志。

-f : 查看實時日志

-t : 查看日志產(chǎn)生的日期

-tail=10 : 查看最后的10條日志。

gitlab : 容器名稱

#日記如非權(quán)限問題,重啟gitlab
docker restart gitlab

#日記報創(chuàng)建目錄 Permission denied(權(quán)限被拒絕) 問題:

解決方案:將selinux關(guān)閉,否則會出現(xiàn) nginx 訪問錯誤 (13: Permission denied),HTTP顯示502
1、臨時關(guān)閉(不用重啟機(jī)器)
setenforce 0 # 只是臨時關(guān)閉,重啟后問題仍然出現(xiàn)
service nginx start  # 重啟nginx

2、修改配置文件需要重啟機(jī)器

#修改/etc/selinux/config 文件
vi /etc/selinux/config 

#將SELINUX=enforcing 改為 SELINUX=disabled,重啟機(jī)器即可
shutdown -r now #重啟服務(wù)器
service gitlab restart #啟動gitlab
添加防火墻訪問端口 (8087端口為例)
$ sudo firewall-cmd --zone=public --add-port=8087/tcp --permanent

$ sudo firewall-cmd --reload 

【注:如果不使用“--permanent”標(biāo)記,把么防火墻規(guī)則在重啟后會失效?!?
配置Gitlab (僅針對http服務(wù))
進(jìn)入docker gitlab 環(huán)境中配置文件
sudo docker exec -it gitlab /bin/bash
備份默認(rèn)gitlab.rb
cd /etc/gitlab
cp gitlab.rb gitlab.rb.back
配置gitlab服務(wù)器的訪問地址
# 進(jìn)入gitlab.rb配置文件
vi /etc/gitlab/gitlab.rb

#配置http協(xié)議所使用的訪問地址
external_url 'http://gitlab.example.com/'

# 配置ssh協(xié)議所使用的訪問地址和端口
gitlab_rails['gitlab_ssh_host'] = 'gitlab.example.com'
gitlab_rails['gitlab_shell_ssh_port'] = 2222

配置郵件服務(wù)(以163的郵箱為例配置smtp服務(wù)器)
# 設(shè)置郵件抬頭發(fā)件人地址
gitlab_rails['gitlab_email_from'] = 'xxxxxxx@163.com'
gitlab_rails['smtp_enable'] = true
gitlab_rails['smtp_address'] = "smtp.163.com" 
gitlab_rails['smtp_port'] = 25 
gitlab_rails['smtp_user_name'] = "xxxxxxx@163.com"
gitlab_rails['smtp_password'] = "xxxx"  #自行配置
gitlab_rails['smtp_domain'] = "163.com" 
gitlab_rails['smtp_authentication'] = "login" 
gitlab_rails['smtp_enable_starttls_auto'] = true 
gitlab_rails['smtp_tls'] = false 
gitlab_rails['smtp_openssl_verify_mode'] = 'none'
# 設(shè)置郵件抬頭發(fā)件人昵稱
user['git_user_name'] = "GitLab"


#郵件功能調(diào)試命令(容器里)
1、gitlab-rails console
2、Notify.test_email('xxxxxxx@163.com', 'Message Subject', 'Message Body').deliver_now
配置重載
gitlab-ctl reconfigure
gitlab-ctl restart

# docker gitlab環(huán)境外 配置重載
docker exec -t gitlab gitlab-ctl reconfigure
docker exec -t gitlab gitlab-ctl restart

【注:】每次修改gitlab.rb配置文件之后,在容器里執(zhí)行g(shù)itlab-ctl reconfigure命令,或者重啟容器以讓新配置生效。
修改HTTP連接方式中的IP和端口
#修改gitlab.yml文件 
vi /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml

gitlab
     host:要修改的IP
     port:要修改的端口
     
#gitlab-ctl restart 重啟gitlab-ctl
  • 編輯反向代理服務(wù)器配置文件 (搭建其他端口的情況下,訪問失敗可通過反向代理解決)
# vi /etc/hosts 文件下寫入如下內(nèi)容:
127.0.0.1   gitlab.example.com

例: cd /usr/local/nginx/conf/vhost #進(jìn)入nginx配置文件目錄
    vi gitlab-runner.conf #新建配置
    
#gitlab-runner.conf 寫入如下內(nèi)容
server
{
    listen 80;
    server_name gitlab.example.com;
    location / {
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://gitlab.example.com:8087;
    }
    access_log logs/gitlab-example.com.tk_access.log;
}

systemctl restart nginx #重啟nginx 
  • 服務(wù)器斷電后 提示docker報錯
#docker服務(wù)器未啟動

'Redirecting to /bin/systemctl stop'報錯 
systemctl start docker #啟動docker
systemctl stop docker #停止docker
systemctl restart docker #重啟docker
systemctl status docker #查看docker狀態(tài)
systemctl enable docker #開機(jī)啟動
搭建Gitlab CI Runner (作業(yè)環(huán)境下配置)
下載安裝包并設(shè)置執(zhí)行權(quán)限(linux安裝包)
sudo curl --output /usr/local/bin/gitlab-runner https://gitlab-ci-multi-runner-downloads.s3.amazonaws.com/latest/binaries/gitlab-ci-multi-runner-linux-amd64
給gitlab-runner賦可執(zhí)行權(quán)限
sudo chmod +x /usr/local/bin/gitlab-runner
創(chuàng)建Gitlab CI(www)用戶
sudo useradd --comment 'www' --create-home www --shell /bin/bash

#注:如使用已存在用戶可不創(chuàng)建
注冊runner
  • 運行命令 sudo gitlab-runner register

  • 按照如下示例配置

# 填寫gitlab ci地址(選擇項目->Settings->CI/CD->Runners查看地址令牌信息)
Please enter the gitlab-ci coordinator URL (e.g. https://gitlab.com )
http://gitlab.example.com:8087/
# 輸入您獲得的注冊Runner的令牌:
Please enter the gitlab-ci token for this runner
GaSz************H1QL

# 輸入Runner的描述,你可以稍后在GitLab的UI中進(jìn)行更改:
Please enter the gitlab-ci description for this runner
[hostame] my-runner

# 輸入與Runner關(guān)聯(lián)的標(biāo)簽,稍后可以在GitLab的UI中進(jìn)行更改:
Please enter the gitlab-ci tags for this runner (comma separated):
my-tag,another-tag

# 選擇Runner是否應(yīng)該選擇沒有標(biāo)簽的作業(yè),可以稍后在GitLab的UI中進(jìn)行更改(默認(rèn)為false):
Whether to run untagged jobs [true/false]:
[false]: true


選擇是否將Runner鎖定到當(dāng)前項目,稍后可以在GitLab的UI中進(jìn)行更改。Runner特定時有用(默認(rèn)為true):

Whether to lock Runner to current project [true/false]:
[true]: true

# 輸入Runner執(zhí)行者:
Please enter the executor: ssh, docker+machine, docker-ssh+machine, kubernetes, docker, parallels, virtualbox, docker-ssh, shell:
shell
安裝并啟動服務(wù)
#使用www組www用戶 
sudo gitlab-runner install --user=www --working-directory=/home/www
sudo gitlab-runner stop
sudo gitlab-runner start
runner配置文件
/etc/gitlab-runner/config.toml
編寫一個發(fā)布腳本deploy(克隆更新分支) ,放在/usr/local/bin/目錄下
#!/bin/bash
if [ $# -ne 2 ]
then
        echo "arguments error!"
        exit 1
else
        deploy_path="/usr/local/$1/$2"
        if [ ! -d "$deploy_path" ]
        then
                project_path="ssh://git@gitlab.example.com:2222/root/$2.git"
                git clone -b develop $project_path $deploy_path
        else
                cd $deploy_path
                git stash && git pull origin develop:develop
        fi
fi

#添加腳本文件可執(zhí)行權(quán)限chmod +x /usr/local/bin/deploy
點擊【項目】-【CI配置】,增加一個.gitlab-ci.yml文件,內(nèi)容如下:
# 該ci pipeline適合的場景
stages:
  - deploy
# 定義的任務(wù)1
deploy:
    # 場景為構(gòu)建
    stage: deploy
    # 所需執(zhí)行的腳本
    script:
      - deploy project test
    # 在哪個分支上可用
    only:
      - master
    # 指定哪個ci runner跑該工作
    tags:
      - my-tag

# deploy project test 表示project目錄下,test項目
ssh公鑰添加
1、su www #切換Gitlab CI用戶
2、cd /home/www/.ssh #進(jìn)入ssh
3、將id_rsa.pub 公鑰添加到gitlab項目ssh配置中

注:CI作業(yè)報 Host key verification failed. 錯誤解決方案

'刪除known_hosts中對應(yīng)ip的相關(guān)rsa信息,手動在服務(wù)器執(zhí)行一次ssh操作。'
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容