docker

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > 云和虚拟化 > docker > Docker部署gitlab+gitlab-runner

Docker快速部署gitlab+gitlab-runner实例

作者:新时代的老古董

这篇文章主要介绍了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注册成功。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文