一、介绍
GitLab 是一个利用Ruby on Rails 开发的开源版本控制系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。
它拥有与GitHub类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊天程序(Wall)进行交流。它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找。
二、下载镜像
docker pull gitlab/gitlab-ce:14.3.0-ce.0
三、启动镜像
1、启动命令:
docker run -d \ --hostname IP或者域名 \ --publish 443:443 --publish 888:80 --publish 33:22 \ --name gitlab \ --restart always \ -v /root/mydocker/gitlab/config:/etc/gitlab \ -v /root/mydocker/gitlab/logs:/var/log/gitlab \ -v /root/mydocker/gitlab/data:/var/opt/gitlab \ gitlab/gitlab-ce:14.3.0-ce.0-d:后台运行
--hostname:主机ip
--publish:暴露端口
--name:起名字
--restart:保证一直运行
-v:选择挂载目录
2、测试访问
如果改了80的映射端口,访问后面就需要添加端口
GitlabIP:Port
3、设置密码
进入容器
docker exec -it gitlab /bin/bash
运行客户端
gitlab-rails console -e production
找到root用户
user=User.where(id:1).first
设置密码
user.password='12345678'
确认密码
user.password_confirmation='12345678'
保存密码
user.save!
如图
四、一些问题
1、无法访问问题
可能是由于80映射的端口没有开放
解决办法一、
换一个可用的端口
解决办法二、
可能是防火墙的问题
启动防火墙
systemc start firewalld
添加规则
firewall-cmd --zone=public --add-port=xxx/tcp --permanent
更新配置
firewall-cmd --reload
如果不需要firewall,可以再关闭,已放通端口不受影响
2、后续碰到再加