• 【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对应的远程分支
    
    

  • 相关阅读:
    快速排序和归并排序的非递归形式
    java计算机毕业设计高校防疫物资管理系统MyBatis+系统+LW文档+源码+调试部署
    权威认可!安全狗获CNVD“漏洞信息报送贡献单位”殊荣
    契约锁助力青岛市市立医院:报销、核酸检测及经济类合同电子签
    「运维有小邓」网络设备监控
    制作rpm包实例
    数据治理-数据仓库和商务智能
    前端发展概述
    基于JAVA疫情防控期间人员档案追演示录像上计算机毕业设计源码+系统+mysql数据库+lw文档+部署
    Mask autoencoder的代码解读
  • 原文地址:https://www.cnblogs.com/dy12138/p/16932826.html