docker run -id -p 3000:80 -p 9922:22 -v /Users/danny/gitlab/etc:/etc/gitlab -v /Users/danny/gitlab/log:/var/log/gitlab -v /Users/danny/gitlab/opt:/var/opt/gitlab —restart always —privileged=true —name gitlab yrzr/gitlab-ce-arm64v8参考:https://www.cnblogs.com/liuqingzheng/p/15325288.html
拉取镜像(gitlab的arm64镜像)
docker pull yrzr/gitlab-ce-arm64v8
启动
docker run -id -p 3000:80 -p 9922:22 -v /Users/danny/gitlab/etc:/etc/gitlab -v /Users/danny/gitlab/log:/var/log/gitlab -v /Users/danny/gitlab/opt:/var/opt/gitlab --restart always --privileged=true --name gitlab yrzr/gitlab-ce-arm64v8
'''
命令解释:
-i 以交互模式运行容器,通常与 -t 同时使用命令解释:
-d 后台运行容器,并返回容器ID
-p 3000:80 将容器内80端口映射至宿主机9980端口,这是访问gitlab的端口
-p 9922:22 将容器内22端口映射至宿主机9922端口,这是访问ssh的端口
-v ./gitlab/etc:/etc/gitlab 将容器/etc/gitlab目录挂载到宿主机./gitlab/etc目录下,若宿主机内此目录不存在将会自动创建,其他两个挂载同这个一样
--restart always 容器自启动
--privileged=true 让容器获取宿主机root权限
--name gitlab-test 设置容器名称为gitlab
gitlab/gitlab-ce 镜像的名称,这里也可以写镜像ID
'''
配置url
# 进入到容器内
docker exec -it gitlab /bin/bash
# 修改gitlab.rb
vi /etc/gitlab/gitlab.rb
## 加入如下
# gitlab访问地址,可以写域名。如果端口不写的话默认为80端口.
external_url 'http://101.133.225.166'
# 如果设置了http://101.133.225.166:3000,也要对应修改容器端口映射,可以删除重新启动
docker run -id -p 3000:3000 -p 22:22 -v /Users/danny/gitlab/etc:/etc/gitlab -v /Users/danny/gitlab/log:/var/log/gitlab -v /Users/danny/gitlab/opt:/var/opt/gitlab --restart always --privileged=true --name gitlab yrzr/gitlab-ce-arm64v8
修改root密码
# 进入容器内部
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
访问gitlab
http://localhost:3000/#