阿里云
阿里云多端小程序中小企业获客首选
发表主题 回复主题
  • 855阅读
  • 0回复

[环境部署]使用Docker搭建Gitlab

级别: 论坛版主
发帖
371
云币
447

docker用来隔离应用还是很方便的,一来本身的操作较为简单,二来资源占用也比虚拟机要小得多,三来也较为安全,因为像数据库这样的应用不会再全局暴露端口,同时应用间的通信通过加密和端口转发,更加安全。 /TbJCZ  
^e "4@O"  
tz65Tn_M  
Gitlab是目前比较流行的开源类Github代码管理平台。Gitlab使用Rails开发,使用PostgreSQL或MySQL数据库,Redis做缓存。一般己搭建私有代码仓库,Gitlab通常是首选。这里简单介绍一下dockerized Gitlab。 KD#zsL)3  
rMG[,:V  
Onqapm0  
Gitlab的docker镜像早已有人做好了,并且维护相当不错。大家可以前往其GitHub仓库了解该镜像的情况。官方repo的readme中已经有详细的安装配置方案,这里我简单的梳理一下部署流程。 a.u{b&+9  
\t{4pobo  
r|Uz?  
安装Docker VKXi*F9  
这里以Ubuntu 14.04发行版为例,在bash中输入一下命令安装最新的docker: P `<TO   
:Dr4?6hdr  
zk70D_}L  
sudo apt-get purge docker.io 6R m dt  
curl -s https://get.docker.io/ubuntu/ | sudo sh G8F;fG N  
sudo apt-get update q:vN3#=^qf  
sudo apt-get install lxc-docker sfG9R"  
注意: 如果你使用了阿里最新推出的Docker镜像,那么可以省略本节的步骤。因为阿里云的这个镜像已经自带了1.2版的docker,版本比较新,可以直接使用。 hDJ+Rk@  
7 HL Uk3  
!K_<7iExI\  
安装docker-gitlab S%]4['Y  
使用如下命令可以使Docker下载对应版本的Gitlab镜像: r_ 9"^Er  
=S^vIo)  
Lo'G fHE  
docker pull sameersbn/gitlab:7.5.3 N<(rP1)`v  
上面的命令下载7.5.3版的Gitlab,如果想下载最新版本,可以输入以下命令: iw(`7(*  
LUx'Dm"  
|L;Hd.l7^*  
docker pull sameersbn/gitlab:latest !`U #Pjp.  
下载完成就算完成安装了。也可以Clone刚才的提到的仓库,然后在本机上build镜像: S-6i5H"B&  
Q\~#cLJ/  
|Qpo[E }a  
git clone https://github.com/sameersbn/docker-gitlab.git Pmuk !V}f  
cd docker-gitlab y}QqS/  
docker build --tag="$USER/gitlab" . K/(Z\lL  
注意上面最后一行命令结尾有一个"."符号,不要掉了。 _ Axw$oYS  
Q Na*Y@i  
&@&^k$du8q  
安装PostgreSQL Y% [H:  
Gitlab推荐使用PostgreSQL作为数据库。既然使用了docker,那么我们为何不考虑把所有的组件都用docker包装起来?我们一样可以下载PostgreSQL的镜像完成安装,这种安装更加便捷。 cJ,`71xop,  
6>d 3*   
78mJ3/?rC  
首先输入以下命令下载PostgreSQL镜像: v<} $d.&*  
z_&T>ME  
ijNI6_eU  
docker pull sameersbn/postgresql:latest H,fVF837  
然后我们要为数据库默认的表空间建立目录以存放数据: 2Q/V D,yU  
H#`&!p  
\ ]h$8JwV  
mkdir -p /opt/postgresql/data (n{!~'3  
这里/opt/postgresql/data部分可以替换成你自己希望建立的地址。 如果是使用SELinux,那么还需要改变一下这个目录的安全设置: 7sJGB^vM  
p_sqw~)^%  
vinn|_s%  
sudo chcon -Rt svirt_sandbox_file_t /opt/postgresql/data OdJ=4 x>  
如果没有使用SELinux,可以跳过上面一条命令。 m`3gNox  
M<)Vtn  
0[OlJMVf  
最后使用以下命令行启动数据库: ?rwHkPJ{*  
B{_-k  
52Q~` t7F  
docker run --name=postgresql -d \ ^W,x  
  -e 'DB_NAME=gitlabhq_production' -e 'DB_USER=gitlab' -e 'DB_PASS=password' \ Luh*+l-nO  
  -v /opt/postgresql/data:/var/lib/postgresql \ EO.}{1m=hx  
  sameersbn/postgresql:latest +3;[1dpgf  
这里,"-e"选项后面的内容请不要随意变更,这里的配置都是Gitlab默认的数据库配置,如果没有在后面Gitlab镜像启动的设置里面做相应的修改的话,这里的修改会让程序无法正常运行。 ]FO)U  
YcuHYf5  
U| 1&=8l  
安装Redis oo,3mat2C  
同样,我们可以使用docker来安装Redis: !% yd'"6Dl  
w 259':  
'#Y[(5  
docker pull sameersbn/redis:latest :sb+jk  
然后启动它: 2k""/xMF'  
NIOWjhi[Jn  
ehYGw2  
docker run --name=redis -d sameersbn/redis:latest <3aW3i/jTc  
启动gitlab c:G0=5  
在最终启动Gitlab之前,我们还需要为Gitlab创建一个目录用来存放提交上来的代码,docker-gitlab内部使用/home/git/data这个目录存放代码,我们在容器外部创建一个目录然后在启动的时候挂载到这个路径即可: TYr"yZ([  
'4d+!%2t  
EY 9N{  
mkdir -p /opt/gitlab/data xYWg1e$k  
mkdir -p /opt/gitlab/backups aruT eJF  
同样,如果使用SELinux,需要修改目录的安全配置: <DM:YWNa  
Q |J$ R  
qw%wyj7  
sudo chcon -Rt svirt_sandbox_file_t /opt/gitlab/data ;F'/[l{+  
sudo chcon -Rt svirt_sandbox_file_t /opt/gitlab/backups 0(dXU\Y  
在完成上面所有的步骤以后,我们可以用以下命令启动Gitlab: 6P*2Kg`  
o8lwwM*  
e!~x-P5M`  
docker run --name='gitlab' -d \ ['n;e:*  
  -e 'GITLAB_PORT=10080' -e 'GITLAB_SSH_PORT=10022' \ #>\+6W17U  
  -e 'GITLAB_BACKUPS=monthly' \ 9gokTFoN  
  -p 10022:22 -p 10080:80 \ \a\ApD  
  -v /opt/gitlab/data:/home/gitl/data \ CK+_T}+-  
  -v /opt/gitlab/backups:/home/git/data/backups u0& dDZ  
  sameersbn/gitlab:7.5.3 gkyv[  
上面的命令将使用10080作为Gitlab的Web访问端口,10022将作为ssh push和pull代码的端口。 在本地可以使用浏览器打开http://localhost:10080来访问Gitlab,初始登录网站使用root账户,用户名为root,密码为:5iveL!fe,登录后需要立即修改密码。 UN*XLHio  
S7 Tem:/  
}PDNW  
gitlab参数 wm r8[n&c  
这里解释一下各参数: *aF<#m v  
 Z,osdF  
;eeu 9_$  
-d: 后台运行 mT2Fn8yC1  
-e:配置Gitlab运行的环境变量,这个参数很重要,具体有哪些环境变量,后面列举  /P/S0  
-p: 端口转发规则 Mz sDDP+h  
-v: 共享目录挂载,即docker容器内外数据共享 UE9r1g`z  
Gitlab的环境变量配置比较多,这里列举一下比较重要的Gitlab的环境变量: ?0VLx,kp  
-]h3s >t  
}TCOm_Y/qL  
GITLAB_HOST: 这个是Gitlab服务器的hostname,你需要将此设定为网站的域名或者ip(不带端口号),默认值为localhost,这个值会被Gitlab用来生成repo的链接,所以必须要设置。否则,在创建的repo中,会发现所有的repo链接都是以localhost为hostname。 jreY'y:  
GITLAB_PORT Gitlab网站的访问端口,这里的设置要结合端口转发一起设置,否则会导致网站无法访问,默认值为80 c*g(R.!  
GITLAB_SSH_PORT Gitlab的SSH代码提交方式使用的SSH端口,这里的设置要结合端口转发一起设置,否则会导致代码无法提交,默认值为22。如果是在VPS上部署,这个值请使用别的端口,比如上面提到的10022端口,否则会与VPS原本的SSH端口产生冲突,造成SSH无法登录VPS ~\z\f} w  
GITLAB_BACKUPS Gitlab的自动备份配置,有disable, daily, weekly, monthly四个可选值,默认为disable。建议打开自动备份 =K)au$BE|  
GITLAB_BACKUP_DIR Gitlab自动备份目录,默认值为/home/git/data/backups M/,jHG8v  
zF[>K4  
Wh)QCp0|n  
转载: ? N|B,F  
Github-ouyangzhiping
本人不是云栖社区工作人员。
无论您在使用中遇到什么问题,不要出言不逊!谢谢合作!
发表主题 回复主题
« 返回列表上一主题下一主题

限100 字节
如果您在写长篇帖子又不马上发表,建议存为草稿
 
验证问题: 阿里云官网域名是什么? 正确答案:www.aliyun.com
上一个 下一个
      ×
      全新阿里云开发者社区, 去探索开发者的新世界吧!
      一站式的体验,更多的精彩!
      通过下面领域大门,一起探索新的技术世界吧~ (点击图标进入)