Docker部署GitLab服务器

news2024/12/23 14:24:30

一、GitLab介绍

1.1 GitLab简介

  1. GitLab 是一款基于 Git 的开源代码托管平台,集成了版本控制、代码审查、问题跟踪、持续集成与持续交付(CI/CD)等多种功能,旨在为团队提供一站式的项目管理解决方案。
  2. 借助 GitLab,开发团队可以高效协作,轻松管理代码版本,并通过内置的 DevOps 工具加速开发、测试和部署过程。
  3. GitLab 的独特优势在于其完整的容器化部署方案,官方支持与 Kubernetes 等容器编排平台的无缝集成,使平台更加易于管理、扩展,并支持现代化云原生架构。

1.2 GitLab特点

  1. 全面的功能支持
    • GitLab 不仅是一个代码仓库管理工具,还提供自动化构建、测试、部署等强大的 DevOps 功能,是现代化软件开发和团队协作的理想选择。
  2. Web 管理界面
    • 基于 Web 的操作界面,方便用户在浏览器中进行仓库管理、代码审查和 CI/CD 配置。

主要功能特点:

  • 代码仓库管理
    • 支持分支管理、合并请求(Merge Requests)和代码审查等功能,为团队提供高效的协作环境。
  • 代码托管
    • 无论是私有服务器还是公共云平台,GitLab 都支持全面的代码托管方案,满足不同规模团队的需求。
  • 内置 CI/CD 工具
    • GitLab 提供持续集成和持续交付工具,支持自动化构建、测试和部署,并包含强大的可视化管道编辑器和测试报告功能。
  • 安全管理
    • 支持多级用户权限、角色管理、双因素身份验证(2FA)、代码扫描和漏洞检测等功能,全面保障代码安全。
  • DevOps 平台
    • GitLab 提供完整的 DevOps 生命周期管理,包括计划、创建、验证、发布、配置和监控,助力团队高效协作,加速软件交付。

二、本次实践介绍

2.1 本地环境规划

本次实践为个人测试环境,操作系统版本为centos7.9。

hostnameIP地址操作系统版本Docker版本
docker192.168.1.50centos 7.926.1.4

2.2 本次实践介绍

1.本次实践部署环境为个人测试环境,生产环境请谨慎使用;
2.在Docker环境下成功部署GitLab服务器。

三、本地环境检查

3.1 检查Docker服务状态

检查Docker服务是否正常运行,确保Docker正常运行。

[root@localhost /]# systemctl status docker
● docker.service - Docker Application Container Engine
   Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)
   Active: active (running) since 六 2024-12-21 23:07:14 CST; 3h 29min ago
     Docs: https://docs.docker.com
 Main PID: 34141 (dockerd)
    Tasks: 67
   Memory: 151.2M
   CGroup: /system.slice/docker.service

docker安装教程:https://note.wym123.cn/docker/install/

3.2 检查Docker版本

检查Docker版本

[root@localhost /]# docker version
Client: Docker Engine - Community
 Version:           26.1.4
 API version:       1.45
 Go version:        go1.21.11
 Git commit:        5650f9b
 Built:             Wed Jun  5 11:32:04 2024
 OS/Arch:           linux/amd64
 Context:           default

Server: Docker Engine - Community
 Engine:
  Version:          26.1.4
  API version:      1.45 (minimum version 1.24)
  Go version:       go1.21.11
  Git commit:       de5c9cf
  Built:            Wed Jun  5 11:31:02 2024
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          1.6.33
  GitCommit:        d2d58213f83a351ca8f528a95fbd145f5654e957
 runc:
  Version:          1.1.12
  GitCommit:        v1.1.12-0-g51d5e94
 docker-init:
  Version:          0.19.0
  GitCommit:        de40ad0

3.3 检查docker compose 版本

检查Docker compose版本,确保2.0以上版本。

[root@localhost /]# docker compose version
Docker Compose version v2.27.1

三、Docker Compse版本升级(可选)

1. 从 GitHub 下载 Docker Compose

  1. 打开 GitHub Docker Compose 官方发布页面:
    • 地址:https://github.com/docker/compose/releases
  2. 找到需要的版本,下载适合你的系统架构的二进制文件(如 Linux 的 docker-compose-linux-x86_64)。

在这里插入图片描述

提示: 如果最新版没有提供二进制文件,可以选择较低版本,直到找到对应的文件。


2. 上传到 Linux

  1. 将下载的文件通过工具(如 scpWinSCP)上传到 /usr/local/bin 目录:

    scp docker-compose-linux-x86_64 root@<your-server-ip>:/usr/local/bin/
    
  2. 上传后,将文件重命名为 docker-compose

    mv /usr/local/bin/docker-compose-linux-x86_64 /usr/local/bin/docker-compose
    

3. 添加执行权限

为二进制文件添加可执行权限:

chmod +x /usr/local/bin/docker-compose

4. 验证安装

  1. 查看 Docker Compose 版本,验证是否安装成功:

    docker-compose version
    
  2. 如果提示权限错误(如 Permission denied),需要重新添加可执行权限:

    chmod +x /usr/local/bin/docker-compose
    

四、下载GitLab镜像

从docker hub下载GitLab镜像

[root@docker gitlab]# docker pull gitlab/gitlab-ce:latest
latest: Pulling from gitlab/gitlab-ce
7b1a6ab2e44d: Already exists
6c37b8f20a77: Pull complete
f50912690f18: Pull complete
bb6bfd78fa06: Pull complete
2c03ae575fcd: Pull complete
839c111a7d43: Pull complete
4989fee924bc: Pull complete
666a7fb30a46: Pull complete
Digest: sha256:5a0b03f09ab2f2634ecc6bfeb41521d19329cf4c9bbf330227117c048e7b5163
Status: Downloaded newer image for gitlab/gitlab-ce:latest
docker.io/gitlab/gitlab-ce:latest

五、部署GitLab服务器

5.1 创建目录

  1. 创建 GitLab 数据目录
    为了确保容器内的 GitLab 数据持久化,需要在宿主机上创建专用目录。执行以下命令:

    mkdir -p /data/gitlab/{data,logs,config} && cd /data/gitlab/
    
    • /data/gitlab/data:存储 GitLab 的数据(如仓库和数据库)。
    • /data/gitlab/logs:存储 GitLab 的日志文件。
    • /data/gitlab/config:存储 GitLab 的配置文件。
    • && cd /data/gitlab/:进入创建的主目录。

5.2 编辑 docker-compose.yml 文件

  1. 创建或编辑 Docker Compose 配置文件: 使用文本编辑器创建并编辑 docker-compose.yml 文件:

    vim /data/gitlab/docker-compose.yml
    
  2. 完整的 docker-compose.yml 示例

    version: "3"
    services:
      gitlab:
        container_name: gitlab  # 容器名称
        image: gitlab/gitlab-ce:latest  # 使用 GitLab 社区版最新镜像
        hostname: '192.168.0.50'  # 配置主机名(本地或虚拟机 IP)
        restart: always  # 容器意外停止时自动重启
        ports:
          - 8088:80         # 映射 HTTP 端口
          - 8443:443      # 映射 HTTPS 端口
          - 2222:22/tcp   # 映射 SSH 端口
        volumes:
          - /etc/localtime:/etc/localtime  # 同步宿主机时间
          - /data/gitlab/data:/var/opt/gitlab  # 数据存储路径
          - /data/gitlab/config:/etc/gitlab  # 配置文件路径
          - /data/gitlab/logs:/var/log/gitlab  # 日志文件路径
        environment:
          GITLAB_OMNIBUS_CONFIG: |
            external_url 'http://192.168.0.50:80'  # 外部访问 URL
            gitlab_rails['gitlab_shell_ssh_port'] = 2222  # 配置 SSH 端口
        deploy:
          resources:
            limits:  # 设置资源限制
              memory: 4G  # 最大内存使用
            reservations:  # 保留资源
              memory: 1G  # 最低内存保留
    

    在这里插入图片描述

注意事项:external_url 中指定的端口号不仅是访问路径的一部分,它还会影响 GitLab 应用本身的监听端口。例如,如果设置为 http://192.168.0.50:8088,GitLab 会在 8088 端口上监听并提供服务(是对于gitlab内部而言的),而不是默认的 80(HTTP)端口, 我们的访问路径是ip+映射后的端口号,不是external_url里面提供的。


5.3 部署 GitLab

  1. 启动容器: 使用 Docker Compose 命令启动 GitLab 容器:

    docker compose up -d
    
    • up:启动容器。
    • -d:以守护进程模式运行容器(后台运行)。
    • 在这里插入图片描述
  2. 运行结果

    • 执行后,Docker Compose 将下载 gitlab/gitlab-ce:latest 镜像并启动容器。

    • 可以通过以下命令查看运行状态:

      docker ps
      
    • 输出示例:

      CONTAINER ID   IMAGE                      COMMAND                  CREATED        STATUS       PORTS                                        NAMES
      123456789abc   gitlab/gitlab-ce:latest   "/assets/wrapper"        2 minutes ago  Up 1 minute  0.0.0.0:80->80/tcp, 0.0.0.0:8443->443/tcp   gitlab
      

六、访问gitlab仓库

6.1 进入 GitLab 登录页

  1. 访问 GitLab Web 界面
    在浏览器中输入以下地址访问 GitLab 登录页:

    http://192.168.0.50:80
    
    • 注意:将 192.168.0.50 替换为您部署 GitLab 的服务器 IP 地址。

    • 如果配置了 HTTPS,则访问地址为:

      https://192.168.0.50:8443
      

    在这里插入图片描述


6.2 获取初始密码

在 GitLab 容器的首次启动过程中,会生成默认的超级管理员账号 root 和随机密码。初始密码可以通过以下命令查看:

  1. 查看初始密码文件
    在容器中查看初始密码:

    docker exec -it gitlab cat /etc/gitlab/initial_root_password
    

    输出示例:

    Password: KfK95J1yFzESkYkNjEkj
    

    说明

    • 密码文件位于 /etc/gitlab/initial_root_password
    • 该密码仅在首次启动时有效。
  2. 删除初始密码文件(可选)
    为了安全起见,可以在记下初始密码后删除该文件:

    docker exec -it gitlab rm /etc/gitlab/initial_root_password
    

6.3 重置登录密码(如有需要)

如果遗忘了超级管理员密码,可以通过以下步骤进行重置:

  1. 进入 GitLab 容器内部
    使用 Docker 命令进入容器:

    docker exec -it gitlab /bin/bash
    
    • docker exec:在运行中的容器内执行命令。
    • gitlab:GitLab 容器的名称。

    输出示例:

    [root@docker gitlab]# docker exec -it gitlab /bin/bash
    root@192:/#
    
  2. 进入 Rails 控制台
    启动 GitLab 的 Rails 控制台:

    gitlab-rails console -e production
    
    • -e production:以生产环境模式启动控制台。
  3. 查询超级管理员用户
    查询超级管理员用户信息(默认用户 ID 为 1):

    user = User.where(id: 1).first
    

    示例图片:
    在这里插入图片描述

  4. 修改密码
    设置新的密码(以 admin36987 为例):

    user.password = 'admin36987'
    
  5. 保存修改并退出
    保存新密码并退出控制台:

    user.save!  # 保存更改
    exit        # 退出控制台
    

    示例图片:
    在这里插入图片描述


6.4 访问 GitLab 首页

  1. 使用初始密码或修改后的账号密码登录 GitLab:

    • 用户名root
    • 密码:初始密码或修改后的密码(如 admin36987)。

    修改密码:
    在这里插入图片描述

  2. 首次登录时提示设置新密码
    如果使用初始密码登录,GitLab 会提示您设置新密码。


6.5 设置中文语言

  1. 进入 Preferences 页面
    登录后,点击右上角头像,进入 Preferences 页面:

    Profile > Preferences
    
  2. 修改语言设置
    Preferences 页面找到 Localization 区域,将 Language 选项修改为 简体中文

    示例图片:

    • 修改前:
      在这里插入图片描述

    • 修改后:
      在这里插入图片描述

  3. 保存设置
    点击保存按钮,刷新界面后语言会立即切换为简体中文。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2264271.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL基础笔记(三)

在此特别感谢尚硅谷-康师傅的MySQL精品教程 获取更好的阅读体验请前往我的博客主站! 如果本文对你的学习有帮助&#xff0c;请多多点赞、评论、收藏&#xff0c;你们的反馈是我更新最大的动力&#xff01; 创建和管理表 1. 基础知识 1.1 一条数据存储的过程 存储数据是处理数…

使用qemu搭建armv7嵌入式开发环境

目录 目录 1 概述 2 环境准备 2.1 vexpress系列开发板介绍 2.2 安装工具 2.2.1 安装交叉工具链 2.2.2 安装qemu 2.2.3 安装其他工具 3 启动uboot 3.1 uboot下载与编译 3.1.1 下载 3.1.2 编译 3.2 使用qemu启动uboot 4 启动kernel 4.1 下载和编译kernel 4.1.1 下…

数据思维的哲学思考

引言 天地合而万物生&#xff0c;阴阳接而变化起。 《荀子礼论》 数据思维的哲学基础源于唯物主义哲学。在马克思的唯物主义思想中&#xff0c;世界是物质的&#xff0c;物质是运动的&#xff0c;运动是有规律的&#xff0c;规律是客观的。 数据思维的哲学基础就是&#xff…

Dijkstra(迪杰斯特拉)最短路径算法可视化演示

Dijkstra(迪杰斯特拉)算法&#xff0c;是一种解决带权图中单源最短路径的经典算法。它由荷兰计算机科学家 Edsger Dijkstra 于1956年提出。在现实生活中&#xff0c;这个算法被广泛应用于导航系统、网络路由等场景。 比如在地图导航中&#xff0c;城市可以看作图中的节点&…

利用深度纹理实现全局雾效

1、为什么要实现屏幕后处理效果的全局雾效 既然Unity中已经提供了全局雾效&#xff0c;那为什么还要自己来实现呢&#xff1f;主要是因为Unity自带的全局雾效有以下几个缺点&#xff1a; 需要为每个自定义Shader按规则书写雾效处理代码自带的全局雾效无法实现一些自定义效果&…

解决“SVN无法上传或下载*.so、*.a等二进制文件“问题

今天&#xff0c;在使用Subversion提交代码到服务器时&#xff0c;发现无法提交*.a、*.so等二进制文件&#xff0c;右击这些文件&#xff0c;发现其属性为ignores。     问题原因&#xff1a;SVN的配置文件里&#xff0c;屏蔽了*.a、*.so文件的上传与下载&#xff0c;并把这些…

Linux下学 〖MySQL 〗表的属性之约束条件(下)(自增长auto_increament、唯一键unique key、外键foreign key)

绪论​ 每日激励&#xff1a;“不是看到希望才坚持&#xff0c;而是坚持了才有希望。—Jack” 绪论​&#xff1a; 本章是约束的下半篇&#xff0c;它将带你认识到一些在字段中非常常用的约束条件&#xff0c;自增长AUTO_CREMENT、唯一键UNIQUE KEY 和 外键FOREIGN KEY这三个。…

观察者模式(sigslot in C++)

大家&#xff0c;我是东风&#xff0c;今天抽点时间整理一下我很久前关注的一个不错的库&#xff0c;可以支持我们在使用标准C的时候使用信号槽机制进行观察者模式设计&#xff0c;sigslot 官网&#xff1a; http://sigslot.sourceforge.net/ 本文较为详尽探讨了一种观察者模…

内置函数.

日期函数 current_date/time() 日期/时间 获得年月日&#xff1a; 获得时分秒&#xff1a; 获得时间戳&#xff1a;日期时间 now()函数 体会date(datetime)的用法&#xff1a;只显示日期 在日期的基础上加日期&#xff1a;按照日历自动计算 关键字为 intervalinterval 后的数值…

web实验三

web实验三 三四个小时左右吧&#xff0c;做成功了学到新东西了&#xff0c;还是挺有趣的&#xff0c;好玩。还有些功能没做完&#xff0c;暂时这样了&#xff0c;要交了。 html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF…

36. Three.js案例-创建带光照和阴影的球体与平面

36. Three.js案例-创建带光照和阴影的球体与平面 实现效果 知识点 Three.js基础 WebGLRenderer WebGLRenderer 是Three.js中最常用的渲染器&#xff0c;用于将场景渲染到网页上。 构造器 new THREE.WebGLRenderer(parameters)参数类型描述parametersobject可选参数&#…

windows平台小熊猫C++安装fmt库

前言 Windows安装C第三方库有点不容易&#xff0c;使用VS的可能还好点&#xff0c;有vcpkg工具用。使用其他工具的就麻烦了&#xff0c;因为基本上第三方库&#xff0c;都默认你是Linux平台&#xff0c;给的安装方式教程都是清一色Cmake&#xff0c;Windows上没有cmake&#x…

信号处理相关的东东(学习解惑)

信号处理相关的东东&#xff08;学习解惑&#xff09; 所有内容学习自知乎专栏&#xff0c;https://www.zhihu.com/column/xinhao&#xff0c;写的很好&#xff0c;值得反复学习 时频域分析的一些常用概念 FROM&#xff1a;https://zhuanlan.zhihu.com/p/35742606 1、相加性…

pset4filter less: helpers.c

&#xff08;&#xff14;&#xff09;blur function 简单画图熟悉一下要做什么 可以看到3种情况&#xff0c;顶格&#xff0c;边界&#xff0c;里面如果分开算的话&#xff0c;是真的麻烦&#xff1b;但是当时还真的没有想到更好的&#xff0c;就先写一写&#xff08;此处摘取…

3. Kafka入门—安装与基本命令

Kafka基础操作 一. 章节简介二. kafka简介三. Kafka安装1. 准备工作2. Zookeeper安装2.1 配置文件2.2 启动相关命令3. Kafka安装3.1 配置文件3.2 启动相关命令-------------------------------------------------------------------------------------------------------------…

某政银行APP登陆逆向

版本 V10.0.0 环境检测 {"xposed": {"action": "warn_and_exit","msg": {"zh_CN": "检测到您的设备安装有Xposed框架&#xff0c;存在非法攻击风险&#xff01;"},"button": {"zh_CN": &qu…

51c自动驾驶~合集42

我自己的原文哦~ https://blog.51cto.com/whaosoft/12888355 #DriveMM 六大数据集全部SOTA&#xff01;最新DriveMM&#xff1a;自动驾驶一体化多模态大模型&#xff08;美团&中山大学&#xff09; 近年来&#xff0c;视觉-语言数据和模型在自动驾驶领域引起了广泛关注…

算法题(12): 特殊年份

审题&#xff1a; 需要输出特殊年份的个数 思路&#xff1a; 获取数据&#xff1a;用字符串获取&#xff0c;然后全部加到总字符串s上判断 使用for循环对每一个四位数年分进行判断&#xff0c;如果是特殊年份就让负责记录的cou变量 解题&#xff1a; 注意&#xff1a;为什么我们…

RuoYi-Vue 数据权限控制示例nvliz (作业机器版)

目录 需求分析 ​编辑建表 代码编写 service层 Mapper层 测试 修改数据权限 添加数据 需求分析 建表 在若依的数据库中建立设备表&#xff1a;equipment 代码编写 使用代码生成&#xff0c;设备管理信息界面&#xff0c;如下图&#xff1a; 使用RuoYi的代码生成的功…

汽车IVI中控开发入门及进阶(三十八):手机投屏HiCar开发

手机投屏轻松实现手机与汽车的无缝连接,导航、音乐、通话等功能应有尽有,还支持更多第三方应用,让车载互联生活更加丰富多彩。 HiCar在兼容性和开放性上更具优势。 手机投屏可以说是车机的杀手级应用,大大拓宽了车机的可用性范围。其中华为推出的HiCar就是非常好用的一种。…