這篇文章主要講解了“Docker-compose怎么一鍵部署gitlab中文版”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Docker-compose怎么一鍵部署gitlab中文版”吧!
山城ssl適用于網站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!
一、gitlab介紹
gitlab是利用 ruby on rails 一個開源的版本管理系統(tǒng),實現(xiàn)一個自托管的git項目倉庫,可通過web界面進行訪問公開的或者私人項目。它擁有與github類似的功能,能夠瀏覽源代碼,管理缺陷和注釋??梢怨芾韴F隊對倉庫的訪問,它非常易于瀏覽提交過的版本并提供一個文件歷史庫。團隊成員可以利用內置的簡單聊天程序(wall)進行交流。它還提供一個代碼片段收集功能可以輕松實現(xiàn)代碼復用,便于日后有需要的時候進行查找。
gitlab就是一個代碼倉庫,能夠非常好地實現(xiàn)對代碼的管理和開發(fā)人員之間的團隊協(xié)作。目前應用最為廣泛地就是利用jenkins和gitlab實現(xiàn)持續(xù)集成和部署。官方的推薦配置為2核心cpu和4g內存,這是因為gitlab的整體運行包含了多個進程,如:nginx、postgresql、prometheus、redis等等。
二、安裝docker
1.安裝docker依賴包
[root@gitlab ~]# yum -y install yum-utils device-mapper-persistent-data lvm2
2.添加docker-ce鏡像源并安裝
1.1)國外源(適合在國外工作的朋友)
[root@gitlab ~]# yum-config-manager \ --add-repo \ https://download.docker.com/linux/centos/docker-ce.repo
1.2)國內阿里云源(適合在國內工作的朋友)
[root@gitlab ~]# yum-config-manager \ --add-repo \ http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
2)服務器的包信息下載到本地電腦緩存起來
[root@gitlab ~]# yum makecache fast
3)安裝docker ce
[root@gitlab ~]# yum -y install docker-ce
4)配置下載docker鏡像加速器
國外加速器:
[root@gitlab ~]# curl -ssl https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://bc437cce.m.daocloud.io
國內阿里云加速器:
vim /etc/docker/daemon.json #輸入下面內容并保存: { "registry-mirrors": [https://9w1hl6qt.mirror.aliyuncs.com] }
5)重載systemctl并自動和開啟自啟動docker
[root@gitlab ~]# systemctl daemon-reload [root@gitlab ~]# systemctl start docker [root@gitlab ~]# systemctl enable docker [root@gitlab ~]# docker --version docker version 18.09.0, build 4d60db4
三、安裝docker-compose
下載docker-compose二進制文件并添加執(zhí)行權限
[root@gitlab ~]# curl -l https://github.com/docker/compose/releases/download/1.23.2/docker-compose-`uname -s-uname -m` -o /usr/local/bin/docker-compose % total % received % xferd average speed time time time current dload upload total spent left speed 100 617 0 617 0 0 590 0 --:--:-- 0:00:01 --:--:-- 590 100 11.2m 100 11.2m 0 0 498k 0 0:00:23 0:00:23 --:--:-- 737k [root@gitlab ~]# chmod +x /usr/local/bin/docker-compose [root@gitlab ~]# docker-compose --version docker-compose version 1.23.2, build 1110ad01
四、安裝gitlab
1)編輯docker-compose的yml文件
[root@gitlab ~]# mkdir gitlab [root@gitlab ~]# cd gitlab [root@gitlab gitlab]# vim docker-compose.yml
version: '2' services: gitlab: image: 'twang2218/gitlab-ce-zh:latest' container_name: "gitlab" restart: unless-stopped privileged: true hostname: 'gitlab' environment: tz: 'asia/shanghai' gitlab_omnibus_config: | external_url 'http://ip或者用nginx做反代的域名' gitlab_rails['time_zone'] = 'asia/shanghai' gitlab_rails['smtp_enable'] = true gitlab_rails['smtp_address'] = "smtp.163.com" gitlab_rails['smtp_port'] = 465 gitlab_rails['smtp_user_name'] = "xxxxxx@163.com" gitlab_rails['smtp_password'] = "授權碼" gitlab_rails['smtp_domain'] = "163.com" gitlab_rails['smtp_authentication'] = "login" gitlab_rails['smtp_enable_starttls_auto'] = true gitlab_rails['smtp_tls'] = true gitlab_rails['gitlab_email_from'] = 'xxxxxx@163.com' gitlab_rails['gitlab_shell_ssh_port'] = 22 ports: - '8181:80' - '8443:443' - '22:22' volumes: - /opt/gitlab/config:/etc/gitlab - /opt/gitlab/data:/var/opt/gitlab - /opt/gitlab/logs:/var/log/gitlab
端口映射說明以及注意事項:
gitlab鏡像官方推薦容器80端口映射宿主機8181端口
gitlab鏡像官方推薦容器443端口映射宿主機8443端口
gitlab鏡像官方推薦容器22端口映射宿主機22端口
??頭兩行不能頂頭寫,要分別都空一行,可以去yml文件檢測網站進行檢測:
如你們的檢測如下圖所示,則表示yml文件完全無誤:
下面是在我linux服務器上看到的情況:
2)創(chuàng)建相關目錄
[root@gitlab gitlab]# mkdir -p /opt/gitlab/{config,data,logs} [root@gitlab gitlab]# ls -l /opt/gitlab/ total 0 drwxr-xr-x 2 root root 6 dec 22 12:03 config drwxr-xr-x 2 root root 6 dec 22 12:03 data drwxr-xr-x 2 root root 6 dec 22 12:03 logs
目錄說明如下:
config 存儲 gitlab 配置信息
data 存儲數(shù)據(jù)庫
logs 存儲日志
3)拉取gitlab中文版鏡像
[root@gitlab gitlab]# docker pull twang2218/gitlab-ce-zh:latest latest: pulling from twang2218/gitlab-ce-zh 8ee29e426c26: pull complete 6e83b260b73b: pull complete e26b65fd1143: pull complete 40dca07f8222: pull complete b420ae9e10b3: pull complete a218309dd589: pull complete 5c60fd7ba0ce: pull complete 659c2144b5a3: pull complete 8289bbac0d0e: pull complete 31bbd150e8a7: pull complete 9114e78243fa: pull complete e242e5cd1314: pull complete 0a079dc3f92c: pull complete f0e195b09fd2: pull complete 6e23346e2f58: pull complete 91f00659be69: pull complete a1031bcc5b2c: pull complete e3074327c7b1: pull complete a917618dbe42: pull complete digest: sha256:62686b74c6fca5ece8ed582d03a126c5988423dd8a19ce70e9a22357ffcaf1c8 status: downloaded newer image for twang2218/gitlab-ce-zh:latest [root@gitlab gitlab]# docker images repository tag image id created size twang2218/gitlab-ce-zh latest 18da462b5ff5 4 months ago 1.61gb
4)啟動gitlab的容器
在啟動前,先要修改宿主機的22端口,因為宿主機占用了22端口,所以啟動容器會失敗,因為映射不過來,修改如下:
vim /etc/ssh/sshd_config
默認在第17行修改:port 2222
修改后,重啟sshd:systemctl restart sshd
[root@gitlab gitlab]# netstat -tulnp | grep 22 tcp 0 0 0.0.0.0:2222 0.0.0.0: listen 31889/sshd tcp6 0 0 :::2222 ::: listen 31889/sshd
正式啟動:
[root@gitlab gitlab]# docker-compose up -d creating network "gitlab_default" with the default driver creating gitlab ... done [root@gitlab gitlab]# docker-compose ps name command state ports gitlab /assets/wrapper up (healthy) 0.0.0.0:22->22/tcp, 0.0.0.0:8443->443/tcp, 0.0.0.0:8181->80/tcp [root@gitlab gitlab]# docker ps -a container id image command created status ports names 814e559dc728 twang2218/gitlab-ce-zh:latest "/assets/wrapper" 5 minutes ago up 5 minutes (healthy) 0.0.0.0:22->22/tcp, 0.0.0.0:8181->80/tcp, 0.0.0.0:8443->443/tcp gitlab
5)gitlab設置開機啟動
[root@gitlab gitlab]# chmod +x /etc/rc.local [root@gitlab gitlab]# ls -l /etc/rc.local lrwxrwxrwx 1 root root 13 dec 3 14:31 /etc/rc.local -> rc.d/rc.local [root@gitlab gitlab]# echo "cd /root/gitlab && docker-compose up -d" >> /etc/rc.local [root@gitlab gitlab]# tail -1 /etc/rc.local cd /root/gitlab && docker-compose up -d
6)gitlab管理界面
地址:在瀏覽器輸入yml文件的第12行ip或者域名
用戶:root
密碼:首次登陸需要手動設置密碼
感謝各位的閱讀,以上就是“Docker-compose怎么一鍵部署gitlab中文版”的內容了,經過本文的學習后,相信大家對Docker-compose怎么一鍵部署gitlab中文版這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!