Docker快速部署gitlab+gitlab-runner实例
作者:新时代的老古董
一、概述
为了方便做一些的测试,我一般不会选择直接在服务器上部署gitlab,那太浪费资源了。
一般直接用docker起gitlab,这样即快速便捷,又节约资源。
二、安装docker
安装docker 的方法很多,这里我就不过多阐述了,我选择了最懒的办法,直接通过yum安装。
# 安装依赖环境 [root@docker ~]# yum -y install yum-utils device-mapper-persistent-data lvm2 # 配置阿里云YUM源 [root@docker ~]# yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo # 安装docker [root@docker ~]# yum -y install docker-ce # 设置开机自启动 [root@docker ~]# systemctl enable docker # 配置阿里云docker镜像源 [root@docker ~]# mkdir -p /etc/docker [root@docker ~]# tee /etc/docker/daemon.json << EOF > { > "registry-mirrors": ["https://******.mirror.aliyuncs.com"] > } > EOF [root@docker ~]# cat /etc/docker/daemon.json # 启动docker [root@docker ~]# systemctl start docker # 查看docker是否安装完成 [root@docker ~]# docker -v Docker version 20.10.17, build 100c701
三、启动gitlab
拉取gitlab镜像,并把gitlab的80,443,22端口和关键的目录映射到宿主机上。注意可以
-d 选项指让容器在后台运行。-p 端口映射,主机端口:容器端口,分别把容器内443、80、22端口映射到宿主机的443、8082、222端口。(直接复制CSDN上的命令,可能会报错,不是命令有问题,而是CSDN上块的编码格式有问题。手敲就好了)
[root@docker ~]# docker pull gitlab/gitlab-ce [root@docker ~]# docker run -d -p 443:443 -p 8082:80 -p 222:22 --name gitlab -v /data/gitlab/config:/etc/gitlab -v /data/gitlab/data:/var/opt/gitlab gitlab/gitlab-ce
四、修改配置gitlab
1. 获取gitlab初始密码,因为我在启动容器的时候映射了配置文件目录,就直接在宿主机上搜密码了。
gitlab 的账号是 root,通过初始密码登入gitlab。
[root@docker ~]# grep Password /data/gitlab/config/initial_root_password # 2. Password hasn't been changed manually, either via UI or via command line. Password: jWx7wxw1uVYzPV52WU3F+sUMUT5RLBvBAhupBGcXkHk=
2. 登录后先修改root密码, Menu >> Admin >> Users >> 编辑,有个password,输入新的密码,然后Save changes 。保存完成后,用新密码登录即可。
3. 这里还没结束,你创建一个new project,你会发现,clone地址url 是容器的ID号,但我们改成宿主机IP地址。不然就无法拉取项目代码。进入宿主机的 /data/gitlab/config/ 目录(config目录映射的是哪个目录就进哪个目录)。修改gitlab.rb 文件的内容。
[root@docker ~]# cd /data/gitlab/config/ [root@docker config]# ls gitlab.rb ssh_host_ecdsa_key ssh_host_ed25519_key.pub trusted-certs gitlab-secrets.json ssh_host_ecdsa_key.pub ssh_host_rsa_key initial_root_password ssh_host_ed25519_key ssh_host_rsa_key.pub [root@docker config]# vim gitlab.rb external_url 'http://192.168.194.23:8082' # 配置外部机器访问的ip地址或域名,注意这里的端口号是容器内部80端口映射到主机上的端口号,如果不修改此行,则clone 的http地址会失败。而且gitrunner连接时也会失败。 gitlab_rails['gitlab_ssh_host'] = '192.168.194.23' # 配置ssh 主机IP地址 gitlab_rails['gitlab_shell_ssh_port'] = 222 # 配置ssh端口 nginx['listen_port'] = 80 # 配置nginx 端口号,如果不配,会发现gitlab无法访问。因为它会默认使用上面 external_url 配置的端口号作为gitlab的nginx监听端口。 [root@docker config]# docker restart 容器ID # 重启容器
4. 再次点开项目,查看clone地址,可以看到之前的容器ID已经变成宿主机的IP地址了。而且ssh 和http端口号也都变成了宿主机的端口号了。
五、docker 部署 gitlab-runner
1. GitLab-Runner是配合GitLab-CI进行使用的。一般地,GitLab里面的每一个工程都会定义一个属于这个工程的软件集成脚本,用来自动化地完成一些软件集成工作。当这个工程的仓库代码发生变动时,比如有人push了代码,GitLab就会将这个变动通知GitLab-CI。这时GitLab-CI会找出与这个工程相关联的Runner,并通知这些Runner把代码更新到本地并执行预定义好的执行脚本。
2. 用 docker 部署 gitlab-runner。官方文档上有两种启动方式,分别是使用系统本地目录挂载启动和docker 卷启动,我这里用系统本地目录挂载。
3. 在启动runner 时可以加“--ip” 选项指定容器IP。我这里没加。
详见官网:Run GitLab Runner in a container | GitLab
[root@docker ~]# docker pull gitlab/gitlab-runner:latest [root@docker ~]# docker run -d --name gitlab-runner --restart always -v /srv/gitlab-runner/config:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock gitlab/gitlab-runner:latest
六、注册runner
1. 查看runner 的token。
2. 注册runner,进入容器注册,也可以不进入容器注册。我选择的是进入容器注册。
root@8db9c442c584:/# gitlab-runner register Enter the GitLab instance URL (for example, https://gitlab.com/): # 输入gitlab url http://172.17.0.3/ci # 注意,这里的url写的是gitlab容器的IP地址,不是服务器IP Enter the registration token: # 输入runner 的 token NNv2TXxEqDswX5Px4jbu Enter a description for the runner: # 输入runner名(随意吧) [8db9c442c584]: test Enter tags for the runner (comma-separated): # 输入runner标签 test Registering runner... succeeded runner=NNv2TXxE Enter an executor: custom, docker, docker-ssh, virtualbox, docker+machine, docker-ssh+machine, kubernetes, parallels, shell, ssh: # 输入执行模式 shell Runner registered successfully. Feel free to start it, but if it's running already the config should be automatically reloaded! # 完成设置
3. 注册完成后,我们回gitlab 页面,项目的CI/CD中,查看Runner,可以看到runner已关联到此项目。或者通过管理员账号看。到此gitrunner注册成功。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。