Docker 部署 GitLab CE 完整版教程

简介: GitLab Community Edition(简称GITLAB-CE)是一款开源的DevOps平台,集成了代码仓库管理、版本控制、 issue 跟踪、CI/CD 流水线、Wiki 和容器仓库等功能,为软件开发团队提供一站式的协作解决方案。通过Docker容器化部署GITLAB-CE,可大幅简化安装流程、提高环境一致性,并便于快速扩展和迁移。本文将详细介绍如何通过Docker快速部署GITLAB-CE,并提供生产环境优化建议及故障排查方案。

概述

GitLab Community Edition(GitLab CE)是开源一站式 DevOps 平台,集成代码托管、版本控制、Issue 管理、CI/CD 流水线、Wiki、容器仓库等核心功能。
使用 Docker 容器化部署 可大幅简化安装、保证环境一致性、方便迁移与升级,是个人/企业快速搭建代码托管平台的最优方案。

本文包含:一键部署、持久化配置、登录使用、生产环境加固、高频故障排查,全程可直接复制命令执行。


一、环境准备

1.1 安装 Docker(一键脚本,支持 Ubuntu/CentOS)

bash <(wget -qO- https://xuanyuan.cloud/docker.sh)

安装完成验证:

docker --version
docker compose version
systemctl status docker

1.2 服务器最低要求(必看)

  • CPU:≥2核
  • 内存:≥4GB(低于 2GB 绝对无法启动)
  • 存储:SSD ≥20GB

二、拉取 GitLab CE 镜像

2.1 拉取稳定版(推荐固定版本,避免 latest 自动更新)

# 推荐稳定版
docker pull gitlab/gitlab-ce:19.0.1-ce.0

# 如需使用国内加速镜像
# docker pull docker.xuanyuan.run/gitlab/gitlab-ce:19.0.1-ce.0

2.2 验证镜像

docker images | grep gitlab-ce

三、容器部署(最关键步骤)

3.1 创建持久化目录(数据不丢失)

sudo mkdir -p /data/gitlab/{
   config,logs,data}

3.2 启动 GitLab 容器(标准生产命令)

如果之前运行失败、创建过旧容器,必须先删除:

docker rm -f gitlab

正式启动命令:

docker run -d \
  --hostname gitlab.example.com \
  --publish 80:80 \
  --publish 443:443 \
  --publish 2222:22 \
  --name gitlab \
  --restart always \
  --volume /data/gitlab/config:/etc/gitlab \
  --volume /data/gitlab/logs:/var/log/gitlab \
  --volume /data/gitlab/data:/var/opt/gitlab \
  gitlab/gitlab-ce:19.0.1-ce.0

3.3 端口说明

  • 80:Web 访问端口
  • 443:HTTPS 端口
  • 2222:Git SSH 克隆端口(避免与主机 22 冲突)

四、启动状态检查

4.1 查看容器是否运行

docker ps

看到 gitlab 状态为 Up 即运行正常。

4.2 实时查看初始化日志(必看)

docker logs -f gitlab

出现以下任意一行,代表启动完成:

  • gitlab Reconfigured!
  • Puma starting

首次启动非常慢(小内存机器可能需要 5~10 分钟),耐心等待!


五、登录 GitLab Web 界面

5.1 访问地址

http://你的服务器IP

5.2 获取默认管理员密码(自动生成)

docker exec -it gitlab grep 'Password:' /etc/gitlab/initial_root_password

5.3 登录信息

  • 用户名:root
  • 密码:上面命令输出的字符串

gitlab 登录页

5.4 登录后必须做

  1. 修改 root 密码
  2. 关闭用户注册(后台 → 设置 → 通用)
  3. 配置外部访问 URL
  4. 配置邮件服务

gitlab 主页


六、Git 使用示例(克隆/提交)

由于 SSH 端口改为 2222,克隆命令格式如下:

git clone ssh://git@服务器IP:2222/root/demo.git

HTTP 方式:

git clone http://服务器IP/root/demo.git

七、生产环境优化建议

7.1 服务器资源

  • 内存 ≥8GB
  • CPU ≥4核
  • SSD 存储

7.2 防火墙放行(Ubuntu/Debian)

ufw allow 80
ufw allow 443
ufw allow 2222
ufw reload

7.3 云服务器安全组(阿里云/腾讯云/华为云)

必须开放以下端口:

  • 80
  • 443
  • 2222

7.4 数据备份

# 手动备份
docker exec -it gitlab gitlab-backup create

# 自动备份(配置 gitlab.rb 开启)

八、高频故障排查(最实用)

问题 1:浏览器提示 ERR_CONNECTION_REFUSED(拒绝连接)

原因 99% 是以下之一:

  1. GitLab 还没初始化完成
  2. 80 端口未监听成功
  3. 服务器防火墙没放行
  4. 云服务器安全组未开放端口

排查命令:

# 查看 80 端口是否监听
ss -lntp | grep :80

# 查看最后 50 行日志
docker logs gitlab --tail 50

问题 2:找不到 initial_root_password 文件

说明:GitLab 未初始化完成
解决:继续等待,直到日志出现 Reconfigured

问题 3:容器反复重启

原因:内存不足
解决:升级服务器内存 ≥4GB。

问题 4:Web 打开 502

原因:GitLab 还在启动中 / 资源占用过高
解决:等待 3~5 分钟即可。


九、常用管理命令

# 重启 GitLab
docker restart gitlab

# 停止 GitLab
docker stop gitlab

# 删除容器(保留数据)
docker rm -f gitlab

# 查看实时日志
docker logs -f gitlab

总结(核心要点)

  1. 第一次启动极慢,必须等日志出现 Reconfigured 才能访问
  2. 管理员账号固定为 root,密码自动生成
  3. 80/443/2222 三个端口必须放行
  4. 数据目录在 /data/gitlab,删除容器不会丢失数据
  5. 内存 <4GB 基本无法正常运行
目录
相关文章
|
8天前
|
人工智能 自然语言处理 文字识别
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
Qwen3.7-Max是阿里云百炼面向智能体时代推出的新一代旗舰模型,对标GPT-5.5、Claude Opus 4.7等闭源旗舰。该模型支持百万级token上下文窗口,具备顶级推理能力、多模态搜索与视觉理解增强、流式输出低延迟响应等核心优势,覆盖编程、办公、长周期自主执行等复杂场景。同时支持OpenAI接口兼容,便于系统快速迁移。用户可通过Token Plan团队或节省计划等订阅方式灵活调用,适合企业级高要求场景使用。
3582 15
阿里云百炼Qwen3.7-Max简介:能力、优势、支持订阅计划参考
|
16天前
|
人工智能 开发工具 iOS开发
Claude Code 新手完全上手指南:安装、国产模型配置与常用命令全解
Claude Code 是一款运行在终端环境中的 AI 编程助手,能够直接在命令行中完成代码生成、项目分析、文件修改、命令执行、Git 管理等开发全流程工作。它最大的特点是**任务驱动、终端原生、轻量高效、多模型兼容**,无需图形界面、不依赖 IDE 插件,能够深度融入开发者日常工作流。
3589 13
|
9天前
|
人工智能 自然语言处理 供应链
|
12天前
|
人工智能 Linux BI
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
JeecgBoot AI专题研究 一键脚本:Claude Code + JeecgBoot Skills + DeepSeek 全平台接入 一行命令装好 Claude Code + JeecgBoot Skills + DeepSeek 接入,无需翻墙使用 Claude Code,支持 Wind
2961 7
国内用 Claude Code 终于不用翻墙了:一行命令搞定,自动接 DeepSeek
|
18天前
|
Shell API 开发工具
Claude Code 快速上手指南(新手友好版)
AI编程工具卷疯啦!Claude Code凭借任务驱动+终端原生的特性,成了开发者的效率搭子。本文从安装、登录、切换国产模型到常用命令,手把手带新手快速上手,全程避坑,30分钟独立用起来。
3705 25
|
9天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全+三种模式+记忆体系+实战工作流完整手册
Claude Code 是当前最流行的终端级 AI 编程助手,能够直接在命令行中完成代码生成、项目理解、文件修改、命令执行、错误修复等全流程开发工作。它不依赖图形界面、不占用额外资源,却能深度理解项目结构,自动生成规范代码,大幅提升研发效率。
1448 3
|
3天前
|
存储 定位技术 数据库
CodeGraph 如何让 Claude Code减少 7 成工具调用?
CodeGraph 为 Coding Agent 提供本地代码知识图谱,把函数、类、调用链和框架路由提前整理成“项目地图”,减少盲目搜索和文件读取。它不是新 Agent,而是上下文基础设施,让 Agent 更快找到正确代码路径,平均减少 7 成工具调用。
461 0
|
16天前
|
存储 Linux iOS开发
【2026最新】MarkText中文版Markdown编辑器使用图解(附安装包)
MarkText是一款免费开源、跨平台的Markdown编辑器,主打所见即所得实时预览,支持Windows/macOS/Linux。内置数学公式、流程图、代码高亮、多主题及PDF/HTML导出,是Typora的轻量免费替代首选。(239字)