第一步 下载相关资源
如果是离线版安装则需要下载docker和gitlab:
docker下载地址:[docker官网](https://download.docker.com/linux/static/stable/x86_64/)
gitlab容器的话建议找一台有网的服务器安装完docker之后执行:
docker pull gitlab/gitlab-ce
#查看镜像
docker images
#保存镜像成tar包到本地
docker save -o /xxxx/gitlab.tar gitlab/gitlab-ce:latest
#然后下载到电脑上保存
如果是线上安装,那么直接通过yum,wget,rpm等方式都可以。
第二步 安装docker
将准备好的压缩包解压到服务器上,然后执行以下命令:
#解压
tar -zxvf xxxx.tar.gz /xxx/docker
#将docker复制到系统目录
sudo cp /xxx/docker/* /usr/bin/
准备service文件,想要将docker注册成服务实现开机自启已经通过服务的方式管理则添加以下文件
到/usr/lib/systemd/system/下面,service文件示例:
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target
[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd --selinux-enabled=false
ExecReload=/bin/kill -s HUP $MAINPID
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Uncomment TasksMax if your systemd version supports it.
# Only systemd 226 and above support this version.
#TasksMax=infinity
TimeoutStartSec=0
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
# restart the docker process if it exits prematurely
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s
[Install]
WantedBy=multi-user.target
然后执行以下命令:
#重新加载服务文件
systemctl daemon-reload
#开机自启
systemctl enable docker
#启动docker
systmectl start docker
#检查docker状态
docker ps
第三步 上传gitlab镜像
直接拉取:docker pull gitlab/gitlab-ce
上传镜像到服务器,执行命令:
docker load -i gitlab.tar
#查看镜像
docker images
第四步 创建docker 子网
创建一个docker子网用来给容器使用,避免使用默认子网导致环境问题
# 创建100.0.0.0/16 的网段给容器使用,网络名是nat
docker network create --subnet=100.0.0.0/16 nat
#查看子网
docker network ls
#查看nat子网详细信息以及容器
docker network inspect nat
第五步 运行gitlab容器
执行docker run脚本,指定对外暴露端口,以及映射数据文件夹到外部实现持久化:
docker run --restart=always -d -p 8001:80 -p 8002:443 -p 8003:22
--name gitlab --net nat --privileged=true -v /xxx/gitlab/etc:/etc/gitlab
-v /xxx/gitlab/log:/var/log/gitlab -v /xxx/gitlab/data:/var/opt/gitlab
gitlab/gitlab-ce:latest
#执行之后等待一会,然后执行docker ps命令查看
docker ps -a
#使用命令查看容器详细信息
docker inspect gitlab
第六步 进入容器执行命令
进入容器进行一些配置的修改,由于gitlab的特殊性,有些配置无法通过环境变量或者映射修改
# 进入容器内部
docker exec -it gitlab /bin/bash
#修改/etc/gitlab/gitlab.rb文件
vi /etc/gitlab/gitlab.rb
#gitlab访问地址,可以写域名。如果端口不写的话默认为80端口
external_url 'http://192.168.2.102' 【注意:写你自己机器的IP】
#ssh主机ip
gitlab_rails['gitlab_ssh_host'] = '192.168.2.102'
#ssh连接端口
gitlab_rails['gitlab_shell_ssh_port'] = 8003,
文件修改保存之后,执行gitlab-ctl reconfigure实现gitlab配置重写
容器内部修改启动配置:
vi /var/opt/gitlab/gitlab-rails/etc/gitlab.yml
修改启动文件之后,直接容器内部执行gitlab-ctl restart重启即可,不用重启容器
第七步 查看初始化密码
第一次创建服务时会有个初始化root账号的密码,密码直接在宿主机上看即可,处于gitlab的安装文件夹下面的etc/initial_root_password中,查看之后直接访问gitlab登录即可。
这个安装文件夹是映射出来的外部路径,到这一步,gitlab基本安装完成。