这篇文章用来记录下我在使用docker部署gitlab时候遇到的一些坑。
先介绍下我的环境:
阿里云的轻量应用服务器:2核4G(好像最低要求配置,之前用2核2G的部署,直接给内存溢出),centos7.6

第一步:安装docker

具体安装步骤参考的是docker官方文档,主要就几个步骤就可以完成安装。
1、卸载旧版本

sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

2、安装yum-utils包

sudo yum install -y yum-utils
//配置镜像地址
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
//推荐使用阿里云的地址
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3、安装 Docker 引擎

sudo yum install docker-ce docker-ce-cli containerd.io

按照提示输入y,就会完成安装
4、启动 Docker

sudo systemctl start docker

5、验证是否安装成功

sudo docker run hello-world

docker会拉取hello-world镜像并执行,输出

docker gitlab 无法免密 docker gitlab unhealthy_docker


表示docker安装成功,可以正常使用

centos的 docker官方文档

第二步:使用docker部署gitlab

1、设置卷位置
对于 Linux 用户,将路径设置为/srv/gitlab:
export GITLAB_HOME=/srv/gitlab
对于 macOS 用户,请使用用户的$HOME/gitlab目录:
export GITLAB_HOME=$HOME/gitlab

2、使用 Docker 引擎安装 GitLab

sudo docker run --detach \
  --hostname 替换为你的域名或云服务器的公网ip \
  --publish 443:443 --publish 替换为你想要的端口(如8082):80 --publish 替换为你想要的端口(如8022):22 \
  --name gitlab \
  --restart always \
  --volume $GITLAB_HOME/config:/etc/gitlab \
  --volume $GITLAB_HOME/logs:/var/log/gitlab \
  --volume $GITLAB_HOME/data:/var/opt/gitlab \
  gitlab/gitlab-ce:latest

–hostname 设置访问的地址
–name 设置镜像的别名
–restart 设置系统重启时的操作,always 表示跟随系统启动而启动
gitlab-ce: 表示安装的是gitlab的社区版,免费的,gitlab-ee:表示商业版,需要付费

3、等待gitlab下载安装完
安装完后,通过命令 docker container ls 可以查看当前容器的状态,会提示starting,表示gitlab正在启动中

gitlab的docker部署的官方文档:gitlab docker方式部署

好了,到现在为止,按照官方文档的操作就已经完成

也是踩坑的开始

按照文档操作完后,输入部署时候设置的地址,访问失败
坑1: ERR_UNSAFE_PORT

--publish 10080:80

当端口设置为10080的时,浏览器访问会提示ERR_UNSAFE_PORT,这是因为浏览器默认为这个端口为非安全端口,所以不能使用10080

坑2: ERR_CONNECTION_RESET
端口设置为8082时,访问时提示ERR_CONNECTION_RESET,然后安装网上提示,通过firewall-cmd来设置防火墙放行端口,如:

firewall-cmd --zone=public --add-port=8082/tcp --permanent

但是,并没有什么用,还是访问不了,真是头大

最后还是误打误撞的被解决掉了

docker gitlab 无法免密 docker gitlab unhealthy_gitlab_02


需要在服务区控制台的防火墙手动的添加放行端口坑3: 新版的gitlab的root初始密码,在第一次登录的时候不能手动设置

docker gitlab 无法免密 docker gitlab unhealthy_docker_03


在可以访问部署好的gitlab后,访问地址,傻眼了,怎么和别人的不一样,怎么不能设置root密码。然后翻看gitlab打印的日志

docker gitlab 无法免密 docker gitlab unhealthy_centos_04


它提示把root密码存放到了这个文件内,可以通过命令打开复制密码登录

vim /etc/gitlab/initial_root_password

但是,我在docker里面的gitlab并没有找到这个文件,在非docker方式部署的gitlab,倒是可以找到这个文件。这就很奔溃。
然后,我就索性重置root的密码,机智吧[😂]

重置gitlab的登录密码步骤:
1、获取容器的id或者别名

docker ps

2、进入容器

//gitlab为一开始设置的容器别名,也可以使用容器id
docker exec -it gitlab bash

3、启动Rails控制台

gitlab-rails console -e production

等待执行完,会进入输入模式
4、获取用户,设置密码

//第一个默认为root
user = User.where(id: 1).first
//必须同时更改密码和password_confirmation才能使其正常工作
user.password = '新的密码'
user.password_confirmation = '新的密码'

5、保存

//保存,稍等一会就会执行刚才输入的代码
user.save!

6、退出容器

ctrl+d

然后就可以使用刚才输入的密码登录root账号了