【2022-11-28】Docker部署搭建Gitlab

一、环境准备

1. 准备一台虚拟机\或者购买服务器
2. 虚拟机硬件要求
    2.1 内存不得少于4G,否则启动会报502错误,可自行百度解决,将虚拟机的swap分区调整为2G大小即可
    2.2 CPU2核2G
    2.3 硬盘至少20G
3. 系统镜像
	centos 7.9

二、安装docker

# 安装依赖
yum install -y yum-utils device-mapper-persistent-data lvm2

# 设置yum源
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

# 安装docker
yum install -y docker-ce

# 设置开机启动
systemctl enable docker

# 启动 Docker
systemctl start docker

# 查看版本
docker version

三、拉取Gitlab镜像

# 拉取Gitlab镜像
docker pull gitlab/gitlab-ce:latest

四、容器运行Gitlab

# 创建容器目录
mkdir gitlab gitlab/etc gitlab/log gitlab/opt  

# 运行容器
docker run -id -p 3000:80 -p 9922:22 -v /root/gitlab/etc:/etc/gitlab  -v /root/gitlab/log:/var/log/gitlab -v /root/gitlab/opt:/var/opt/gitlab --restart always --privileged=true --name gitlab gitlab/gitlab-ce

'''
命令解释:
-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
'''

五、修改配置文件

# 进入容器内部
docker exec -it gitlab /bin/bash

# 修改gitlab.rb
vi /etc/gitlab/gitlab.rb
# 加入如下内容
# gitlab访问地址,可以写域名。如果端口不写的话默认为80端口
external_url 'http://101.133.225.166'
# ssh主机ip
gitlab_rails['gitlab_ssh_host'] = '101.133.225.166'
# ssh连接端口
gitlab_rails['gitlab_shell_ssh_port'] = 9922

# 让配置生效
gitlab-ctl reconfigure

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

# 修改http和ssh配置
vi /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.yml

  gitlab:
    host: 101.133.225.166
    port: 3000 # 这里改为3000
    https: false


# 重启
gitlab-ctl restart
# 退出容器
exit

六、浏览器访问

# 使用浏览器访问
	http://192.168.44.180:3000
 
# 用户名默认是root,登录密码看下方,在配置文件中修改后,完成登录

七、修改登录密码

# 进入容器内部
docker exec -it gitlab /bin/bash

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

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

八、创建新的项目

1. 新建项目
2. 创建空白项目
3. 项目名称

九、提交代码

# 使用Git向远端仓库提交代码

# Git全局配置
git config --global user.name "你的名字"
git config --global user.email "你的邮箱"

# 查看origin
git remote

# 如果存在则删除
git remote remove origin

# 配置为远程Gitlab的地址
git remote add origin http://192.168.44.180:3000/gitlab-instance-705ba61b/cops_api.git  
#  我们使用http来推送拉取代码:注意这个ip,如上图,Gitlab自动生成的ip 101.133.225.166:3000是不可以访问的,这里填写你虚拟机的ip+端口号

git add .  					# 提交所有更改
git commit -m '提交说明'	  # 填写注释
git branch -M main			 # -M是每个docs page on git branch的--move --force的标志(快捷方式)。它将分支重命名为main (因为使用命令行创建的存储库的默认分支名称是master,而从2020年10月开始在GitHub中创建的分支具有默认名称main)并强制它(允许重命名分支,即使新的分支名称已经存在)。

git push -uf origin main      # 把本地的主分支推到origin对应的远程分支

posted @ 2022-11-28 17:34  dy12138  阅读(1652)  评论(0编辑  收藏  举报