docker部署gitlab 报错的问题!!!

发布于:2024-03-29 ⋅ 阅读:(19) ⋅ 点赞:(0)

1、什么是gitlab?

Gitlab是一个用于仓库管理系统的开源项目,使用git作为代码管理工具,并在此基础上搭建起来的web服务。Gitlab有乌克兰程序员DmitriyZaporozhets和ValerySizov开发,它由Ruby写成。后来,一些部分用Go语言重写,现今并在国内外大中型互联网公司广泛使用。gitlab-ce是它的社区版,gitlab-ee是企业版,是收费的。

gitlab的官方文档:

注:https://docs.gitlab.com/ee/administration/backup_restore/backup_gitlab.html   

2、docker部署gitlab

言简意赅,进入正题,在之前的文章中,已经详细的讲过了,这篇文章我主要是讲用docker方式部署gitlab的时候遇到的问题,如何解决!

2.1 拉取镜像

docker pull gitlab/gitlab-ce

在这里插入图片描述

2.2 启动容器命令

docker run -itd --name=gitlab --restart=always --privileged=true  \
 -p 8443:443  -p 8090:8090 -p 8022:22  \     #这个地方要注意:8090 容器外是什么端口容器内就得什么端口,否则会报一堆问题,因为这个问题我解决了半天
 -v  /data/gitlab/etc:/etc/gitlab \
 -v  /data/gitlab/log:/var/log/gitlab  \
 -v  /data/gitlab/data:/var/opt/gitlab   \
 -v /etc/localtime:/etc/localtime   \
 gitlab/gitlab-ce 

命令解释:

-i	 以交互模式运行容器,通常与 -t 同时使用命令解释
-t	 为容器重新分配一个伪输入终端,通常与 -i 同时使用
-d	 后台运行容器,并返回容器ID
-p 8090:8090	将容器内8090端口映射至宿主机8090端口,这是访问gitlab的端口
-p 8022:22	将容器内22端口映射至宿主机8022端口,这是访问ssh的端口
-v  /data/gitlab/etc:/etc/gitlab	将容器/etc/gitlab目录挂载到宿主机/data/gitlab/etc目录下,若宿主机内此目录不存在将会自动创建,其他两个挂载同这个一样
--restart always	容器自启动
--privileged=true	让容器获取宿主机root权限
--name gitlab	设置容器名称为gitlab
gitlab/gitlab-ce	镜像的名称,这里也可以写镜像ID

在这里插入图片描述

2.2.1 修改配置文件

接下来的配置请在容器内进行修改,不要在挂载到宿主机的文件上进行修改。
否则可能出现配置更新不到容器内,或者是不能即时更新到容器内,导致gitlab启动成功,但是无法访问
2.2.1.1 开放linux端口,设置白名单

如果你是用的阿里云、华为云,直接在云上面配置白名单,放开对应的网段,新增8090端口;
如果是在服务器上配置如下:

 firewall-cmd --zone=public --add-port=8090/tcp --permanent
 firewall-cmd --zone=public --add-port=8022/tcp --permanent

重启防火墙

firewall-cmd --reload

查询有哪些端口是开启的

firewall-cmd --list-port

2.2.1.2 修改内部配置【解决修改Gitlab的IP地址的问题】
#进容器内部
docker exec -it gitlab /bin/bash
 
#修改gitlab.rb
vi /etc/gitlab/gitlab.rb
 
#加入如下
#gitlab访问地址,可以写域名。如果端口不写的话默认为80端口
external_url 'http://192.168.124.194'    【注意:写你自己机器的IP】
#ssh主机ip
gitlab_rails['gitlab_ssh_host'] = '192.168.124.194'
#ssh连接端口
gitlab_rails['gitlab_shell_ssh_port'] = 8022
 
# 让配置生效
gitlab-ctl reconfigure

注意不要重启,/etc/gitlab/gitlab.rb文件的配置会映射到gitlab.yml这个文件,由于咱们在docker中运行,在gitlab上生成的http地址应该是http://192.168.124.194:8090,所以,要修改下面文件

# 修改http和ssh配置
vi /data/gitlab/data/gitlab-rails/etc/gitlab.yml
 
  gitlab:
    host: 192.168.124.194
    port: 8090 # 这里改为8090
    https: false

修改完之后记得保存退出
然后执行:gitlab-ctl restart
重启gitlab
2.2.1.3 浏览器访问

路径访问:http://192.168.124.194:8090/

# 机器配置要大于4g,否则很容易启动不了,报502

在这里插入图片描述

# 第一次访问,会让修改root密码
# 修改后以root用户登录即可

在这里插入图片描述

2.2.1.3 修改root密码
# 进入容器内部
docker exec -it gitlab /bin/bash
 
# 进入控制台
gitlab-rails console -e production
 
# 查询id为1的用户,id为1的用户是超级管理员
user = User.where(id:1).first
# 修改密码为lhx123456
user.password='lhx123456'
# 保存
user.save!
# 退出
exit

在这里插入图片描述
这样就成功啦,输入账号密码就能进到主页。

本文含有隐藏内容,请 开通VIP 后查看