Docker 部署 GitLab

一、下载镜像

bash 复制代码
docker pull gitlab/gitlab-ce

二、运行容器

bash 复制代码
docker run -d --name gitlab-20080 \n
-p 20443:443 -p 20080:80 -p 20022:22 \n
-v /wwwroot/opt/docker/gitlab-20080/etc:/etc/gitlab \n
-v /wwwroot/opt/docker/gitlab-20080/log:/var/log/gitlab \n
-v /wwwroot/opt/gitlab-20080/gitlab/data:/var/opt/gitlab \n
--privileged=true gitlab/gitlab-ce

这里稍微解释下命令:

-d #后台运行,全称:detach

-p 20443:443 #将容器内部端口向外映射

-p 20080:80 #将容器内80端口映射至宿主机8090端口,这是访问gitlab的端口

-p 20022:22 #将容器内22端口映射至宿主机8022端口,这是访问ssh的端口

--name gitlab-20080 #设置容器名称为gitlab-20080

-v /wwwroot/opt/docker/gitlab-20080/etc:/etc/gitlab #将容器/etc/gitlab目录挂载到宿主机/wwwroot/opt/docker/gitlab-20080/etc目录下,若宿主机内此目录不存在将会自动创建

-v /wwwroot/opt/docker/gitlab-20080/log:/var/log/gitlab #与上面一样

-v /wwwroot/opt/docker/gitlab-20080/data:/var/opt/gitlab #与上面一样

--privileged=true #让容器获取宿主机root权限

gitlab/gitlab-ce #镜像的名称,这里也可以写镜像ID

查看容器运行

bash 复制代码
docker ps

至此,docker 容器启动成功。

三、GitLab配置

进入容器

bash 复制代码
docker exec -it gitlab-20080 bash

记录root初始密码

bash 复制代码
# 记录初始密码
cat /etc/gitlab/initial_root_password

修改gitlab.rb文件

bash 复制代码
# 详见文档 https://docs.gitlab.com/omnibus/settings/nginx.html#using-a-non-bundled-web-server
vi /etc/gitlab/gitlab.rb
bash 复制代码
# 服务地址,可以是域名 如果默认http不用80端口,在ip后加上端口即可
external_url 'http://192.168.1.111:20080'
# 配置ssh协议所使用的访问地址和端口
gitlab_rails['gitlab_ssh_host'] = 'http://192.168.1.111'
# 此端口是run时22端口映射的20022端口
gitlab_rails['gitlab_shell_ssh_port'] = 20022

刷新配置

bash 复制代码
gitlab-ctl reconfigure

配置gitlab.yml文件

bash 复制代码
vi /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml
bash 复制代码
gitlab:
    # 修改host 与上面.rb文件修改的一致,修改port 为8090
    host: 192.168.1.111
    port: 20080
    https: false

重启服务

bash 复制代码
gitlab-ctl restart

本地测试服务

等个两分钟(看机器配置,配置低的启动慢),执行如下命令

bash 复制代码
curl http://127.0.0.1:20080/

出现如下结果,则代表服务启动完成。

浏览器测试服务

url : http://ip:端口/

修改Root密码

如果忘记root密码时可以修改

bash 复制代码
# 进入容器内部
docker exec -it gitlab /bin/bash

# 进入控制台
gitlab-rails console -e production

# 查询id为1的用户,id为1的用户是超级管理员
user = User.where(id:1).first
# 修改密码为lqz123456
user.password='lqz123456'
# 保存
user.save!
# 退出
exit

四、常用命令

bash 复制代码
# 容器外停止
docker stop gitlab-20080  
# 容器外重启
docker restart gitlab-20080
# 进入容器命令行
docker exec -it gitlab-20080 bash
# 容器日志
docker logs -f gitlab-20080
# 容器中应用配置,让修改后的配置生效
gitlab-ctl reconfigure
# 容器中重启服务
gitlab-ctl restart
# 查看gitlab运行状态
gitlab-ctl status
#停止gitlab服务
gitlab-ctl stop
# 查看gitlab运行日志
gitlab-ctl tail
# 停止相关数据连接服务
gitlab-ctl stop unicorn
gitlab-ctl stop sideki
相关推荐
cdg==吃蛋糕41 分钟前
solr cloud集群搭建 solr5+zookeeper
tcp/ip·docker·容器
晓梦初醒p1 小时前
finalshell 连接服务器报错channel is not opened
linux·运维·服务器
准时准点睡觉1 小时前
HTTP 错误 403.14 - Forbidden Web 服务器被配置为不列出此目录的内容——错误代码:0x00000000
运维·服务器·iis·asp.net
cpsvps1 小时前
环境变量管理于美国服务器多环境部署的实施标准
运维·服务器·数据库
IvorySQL1 小时前
【生态再升级】IvorySQL 4.5 与银河麒麟高级服务器操作系统V11完成适配认证!
运维·服务器·数据库·postgresql·ivorysql
段振轩2 小时前
Docker nginx容器部署前端项目。
前端·nginx·docker
conkl2 小时前
在ARM64 Ubuntu 20.04上部署Mailu邮件系统:深度排查Docker Bridge网络通信失败问题
linux·ubuntu·docker
网硕互联的小客服2 小时前
服务器密码错误被锁定如何解决?
运维·服务器·网络·安全
2301_767902642 小时前
NFS 服务器&&iSCSI 服务器
运维·服务器·php
云游2 小时前
Zabbix7.4.8(一):通过Zabbix agent 2监控postgresql相关指标
运维·postgresql·zabbix