docker部署gitlab[通俗易懂]

2022-11-10 16:22:43 浏览数 (1)

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

第一步:安装docker

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

代码语言:javascript复制
sudo yum remove docker 
                  docker-client 
                  docker-client-latest 
                  docker-common 
                  docker-latest 
                  docker-latest-logrotate 
                  docker-logrotate 
                  docker-engine

2、安装yum-utils包

代码语言:javascript复制
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 引擎

代码语言:javascript复制
sudo yum install docker-ce docker-ce-cli containerd.io

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

代码语言:javascript复制
sudo systemctl start docker

5、验证是否安装成功

代码语言:javascript复制
sudo docker run hello-world

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

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

centos的 docker官方文档

第二步:使用docker部署gitlab

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

2、使用 Docker 引擎安装 GitLab

代码语言:javascript复制
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

代码语言:javascript复制
--publish 10080:80 

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

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

代码语言:javascript复制
firewall-cmd --zone=public --add-port=8082/tcp --permanent

但是,并没有什么用,还是访问不了,真是头大 最后还是误打误撞的被解决掉了

需要在服务区控制台的防火墙手动的添加放行端口

坑3: 新版的gitlab的root初始密码,在第一次登录的时候不能手动设置

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

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

代码语言:javascript复制
vim /etc/gitlab/initial_root_password

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

0 人点赞