赞
踩
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
# 查找Gitlab镜像
docker search gitlab
# 拉取Gitlab镜像
docker pull gitlab/gitlab-ce:latest
# 查看Gitlab镜像
docker images
# 启动容器
docker run \
-itd \
-p 9980:80 \
-p 9922:22 \
-v /home/gitlab/etc:/etc/gitlab \
-v /home/gitlab/log:/var/log/gitlab \
-v /home/gitlab/opt:/var/opt/gitlab \
--restart always \
--privileged=true \
--name gitlab \
gitlab/gitlab-ce
命令 | 描述 |
---|---|
-i | 以交互模式运行容器,通常与 -t 同时使用命令解释 |
-t | 为容器重新分配一个伪输入终端,通常与 -i 同时使用 |
-d | 后台运行容器,并返回容器ID |
-p 9980:80 | 将容器内80端口映射至宿主机9980端口,这是访问gitlab的端口 |
-p 9922:22 | 将容器内22端口映射至宿主机9922端口,这是访问ssh的端口 |
-v /home/gitlab/etc:/etc/gitlab | 以交互模式运行容器,通常与 -t 同时使用命令解释 |
–restart always | 将容器/etc/gitlab目录挂载到宿主机/usr/local/gitlab-test/etc目录下,若宿主机内此目录不存在将会自动创建,其他两个挂载同这个一样 |
–privileged=true | 容器自启动 |
–name gitlab | 设置容器名称为gitlab |
gitlab/gitlab-ce | 镜像的名称,这里也可以写镜像ID |
#进容器内部
docker exec -it gitlab /bin/bash
#修改gitlab.rb
vi /etc/gitlab/gitlab.rb
#加入如下
#gitlab访问地址,可以写域名。如果端口不写的话默认为80端口
external_url 'http://192.168.200.250'
#ssh主机ip
gitlab_rails['gitlab_ssh_host'] = '192.168.200.250'
#ssh连接端口
gitlab_rails['gitlab_shell_ssh_port'] = 9922
退出保存
按下 ESC ----> :wq
让修改的配置生效(稍微等待一小会)
gitlab-ctl reconfigure
注意:此时不要退出容器,接着把gitLab使用HTTP方式克隆的端口修改,如果不修改则默认是 80
# 修改http和ssh配置
vi /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml
gitlab:
host: 192.168.200.250
port: 9980 # 这里改为9980
https: false
退出保存
按下 ESC ----> :wq
完成后将修改的内容生效,需要重启gitLab
#重启gitlab
gitlab-ctl restart
#退出容器
exit
浏览器路径访问:http://192.168.200.250:9980/
重点:此时可能出现报502,就说明一且,正常 等待刷新、多刷新几次,根据自己配置来决定等待时间
登录页面
第一次访问,会让修改root密码,修改后以root用户登录即可
# 进入容器内部
docker exec -it gitlab /bin/bash
# 进入控制台
gitlab-rails console -e production
# 查询id为1的用户,id为1的用户是超级管理员
user = User.where(id:1).first
# 修改密码为kang123456,根据需要来决定
user.password='kang123456'
# 保存
user.save!
# 退出
exit
创建新仓库检查,git使用HTTP克隆是否存在9980端口,如果没有,则需要重新进行容器,修改gitlab.yml文件即可,上文有提到。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。