专属域名
文档搜索
轩辕助手
Run助手
邀请有礼
返回顶部
快速返回页面顶部
收起
收起工具栏
轩辕镜像 官方专业版
轩辕镜像 官方专业版轩辕镜像 官方专业版官方专业版
首页个人中心搜索镜像

交易
充值流量我的订单
工具
提交工单镜像收录一键安装
Npm 源Pip 源Homebrew 源
帮助
常见问题
其他
关于我们网站地图

官方QQ群: 1072982923

热门搜索:openclaw🔥nginx🔥redis🔥mysqlopenjdkcursorweb2apimemgraphzabbixetcdubuntucorednsjdk
gitlab

yuankunzhang/gitlab

自动构建
yuankunzhang

sameersbn/gitlab:11.0.2是基于Docker的GitLab CE镜像,通过源码安装方式构建,支持PostgreSQL/MySQL数据库、Redis、SSL加密、邮件配置、多种认证集成及备份维护功能,适用于代码托管与团队协作。

下载次数: 0状态:自动构建维护者:yuankunzhang仓库类型:镜像最近更新:7 年前
使用轩辕镜像,把时间还给真正重要的事。点击查看
中文简介版本下载
使用轩辕镜像,把时间还给真正重要的事。点击查看

sameersbn/gitlab:11.0.2

镜像概述和主要用途

该Docker镜像用于构建基于Docker开源容器平台的GitLab应用。GitLab CE通过源码安装方式在镜像中配置,提供代码托管、版本控制、项目管理等完整功能。适用于个人开发者、团队或企业搭建私有代码仓库和协作平台。

核心功能和特性

  • 多数据库支持:兼容PostgreSQL(推荐)和MySQL数据库,支持外部数据库服务器或容器链接
  • Redis集成:支持外部Redis服务器或容器链接,用于键值数据存储
  • 安全特性:支持SSL加密、HSTS配置、负载均衡HTTPS部署及可信证书安装
  • 邮件配置:支持SMTP发送邮件和IMAP接收邮件(回复评论功能)
  • 认证集成:支持OmniAuth(CAS3、Google、GitHub、SAML等)和外部问题跟踪器
  • 数据持久化:通过卷挂载确保代码和配置数据不丢失
  • 维护功能:提供备份创建、恢复、自动化备份(支持AWS、GCS)及Rake任务执行
  • 容器 registry:集成容器镜像仓库功能

使用场景和适用范围

  • 个人开发者搭建私有代码仓库
  • 中小型团队协作开发平台
  • 需要本地化部署GitLab的企业环境
  • 对数据安全和隐私有较高要求的组织
  • 希望通过Docker简化部署和维护的场景

详细的使用方法和配置说明

前提条件

  • Docker主机需至少1GB可用内存(详见GitLab https://github.com/gitlabhq/gitlabhq/blob/master/doc/install/requirements.md#hardware-requirements%EF%BC%89
  • 安装最新版Docker引擎(可通过wget -qO- https://get.docker.com/ | sh安装)

安装

推荐通过Docker Hub获取自动化构建镜像:

bash
docker pull sameersbn/gitlab:11.0.2

也可拉取latest标签(基于仓库HEAD构建):

bash
docker pull sameersbn/gitlab:latest

或本地构建:

bash
docker build -t sameersbn/gitlab github.com/sameersbn/docker-gitlab

快速启动

使用docker-compose(推荐)

  1. 下载docker-compose.yml:
bash
wget https://raw.githubusercontent.com/sameersbn/docker-gitlab/master/docker-compose.yml
  1. 生成至少64位的随机字符串,分别设置为GITLAB_SECRETS_OTP_KEY_BASE、GITLAB_SECRETS_DB_KEY_BASE和GITLAB_SECRETS_SECRET_KEY_BASE(可使用pwgen -Bsv1 64生成)

  2. 启动服务:

bash
docker-compose up

手动启动

  1. 启动PostgreSQL容器:
bash
docker run --name gitlab-postgresql -d \
    --env 'DB_NAME=gitlabhq_production' \
    --env 'DB_USER=gitlab' --env 'DB_PASS=password' \
    --env 'DB_EXTENSION=pg_trgm' \
    --volume /srv/docker/gitlab/postgresql:/var/lib/postgresql \
    sameersbn/postgresql:9.6-2
  1. 启动Redis容器:
bash
docker run --name gitlab-redis -d \
    --volume /srv/docker/gitlab/redis:/var/lib/redis \
    sameersbn/redis:latest
  1. 启动GitLab容器:
bash
docker run --name gitlab -d \
    --link gitlab-postgresql:postgresql --link gitlab-redis:redisio \
    --publish 10022:22 --publish 10080:80 \
    --env 'GITLAB_PORT=10080' --env 'GITLAB_SSH_PORT=10022' \
    --env 'GITLAB_SECRETS_DB_KEY_BASE=long-and-random-alpha-numeric-string' \
    --env 'GITLAB_SECRETS_SECRET_KEY_BASE=long-and-random-alpha-numeric-string' \
    --env 'GITLAB_SECRETS_OTP_KEY_BASE=long-and-random-alpha-numeric-string' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

启动后,访问http://localhost:10080并设置root用户密码即可使用。

配置

数据存储

为避免数据丢失,需挂载卷到/home/git/data:

bash
mkdir -p /srv/docker/gitlab/gitlab
# SELinux用户需执行:sudo chcon -Rt svirt_sandbox_file_t /srv/docker/gitlab/gitlab
docker run --name gitlab -d \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

数据库配置

PostgreSQL(推荐)

外部PostgreSQL服务器

  1. 创建数据库和用户:
sql
CREATE ROLE gitlab with LOGIN CREATEDB PASSWORD 'password';
CREATE DATABASE gitlabhq_production;
GRANT ALL PRIVILEGES ON DATABASE gitlabhq_production to gitlab;
-- GitLab 8.6.0+需加载pg_trgm扩展
\c gitlabhq_production
CREATE EXTENSION pg_trgm;
  1. 启动GitLab(假设PostgreSQL主机为192.168.1.100):
bash
docker run --name gitlab -d \
    --env 'DB_ADAPTER=postgresql' --env 'DB_HOST=192.168.1.100' \
    --env 'DB_NAME=gitlabhq_production' \
    --env 'DB_USER=gitlab' --env 'DB_PASS=password' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

链接PostgreSQL容器

使用https://github.com/sameersbn/docker-postgresql%E9%95%9C%E5%83%8F%EF%BC%9A

bash
docker run --name gitlab-postgresql -d \
    --env 'DB_NAME=gitlabhq_production' \
    --env 'DB_USER=gitlab' --env 'DB_PASS=password' \
    --env 'DB_EXTENSION=pg_trgm' \
    --volume /srv/docker/gitlab/postgresql:/var/lib/postgresql \
    sameersbn/postgresql:9.6-2

docker run --name gitlab -d --link gitlab-postgresql:postgresql \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

MySQL

外部MySQL服务器

  1. 创建数据库和用户:
sql
CREATE USER 'gitlab'@'%.%.%.%' IDENTIFIED BY 'password';
CREATE DATABASE IF NOT EXISTS `gitlabhq_production` DEFAULT CHARACTER SET `utf8` COLLATE `utf8_unicode_ci`;
GRANT ALL PRIVILEGES ON `gitlabhq_production`.* TO 'gitlab'@'%.%.%.%';
  1. 启动GitLab(假设MySQL主机为192.168.1.100):
bash
docker run --name gitlab -d \
    --env 'DB_ADAPTER=mysql2' --env 'DB_HOST=192.168.1.100' \
    --env 'DB_NAME=gitlabhq_production' \
    --env 'DB_USER=gitlab' --env 'DB_PASS=password' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

链接MySQL容器

使用https://github.com/sameersbn/docker-mysql%E9%95%9C%E5%83%8F%EF%BC%9A

bash
docker run --name gitlab-mysql -d \
    --env 'DB_NAME=gitlabhq_production' \
    --env 'DB_USER=gitlab' --env 'DB_PASS=password' \
    --volume /srv/docker/gitlab/mysql:/var/lib/mysql \
    sameersbn/mysql:latest

docker run --name gitlab -d --link gitlab-mysql:mysql \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

Redis配置

外部Redis服务器

bash
docker run --name gitlab -d \
    --env 'REDIS_HOST=192.168.1.100' --env 'REDIS_PORT=6379' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

链接Redis容器

使用https://github.com/sameersbn/docker-redis%E9%95%9C%E5%83%8F%EF%BC%9A

bash
docker run --name gitlab-redis -d \
    --volume /srv/docker/gitlab/redis:/var/lib/redis \
    sameersbn/redis:latest

docker run --name gitlab -d --link gitlab-redis:redisio \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

邮件配置

发送邮件(SMTP)

以Gmail为例:

bash
docker run --name gitlab -d \
    --env 'SMTP_USER=USER@gmail.com' --env 'SMTP_PASS=PASSWORD' \
    --env 'SMTP_DOMAIN=gmail.com' --env 'SMTP_HOST=smtp.gmail.com' \
    --env 'SMTP_PORT=587' --env 'SMTP_STARTTLS=true' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

回复邮件(IMAP)

以Gmail为例(支持邮件回复评论):

bash
docker run --name gitlab -d \
    --env 'IMAP_USER=USER@gmail.com' --env 'IMAP_PASS=PASSWORD' \
    --env 'IMAP_HOST=imap.gmail.com' --env 'IMAP_PORT=993' \
    --env 'IMAP_SSL=true' \
    --env 'GITLAB_INCOMING_EMAIL_ADDRESS=USER+%{key}@gmail.com' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

SSL配置

生成自签名证书

bash
# 生成私钥
openssl genrsa -out gitlab.key 2048
# 生成CSR
openssl req -new -key gitlab.key -out gitlab.csr
# 生成证书
openssl x509 -req -days 3650 -in gitlab.csr -signkey gitlab.key -out gitlab.crt
# 生成DHE参数(增强安全性)
openssl dhparam -out dhparam.pem 2048

安装证书

将gitlab.key、gitlab.crt和dhparam.pem放入数据卷的certs目录:

bash
mkdir -p /srv/docker/gitlab/gitlab/certs
cp gitlab.key gitlab.crt dhparam.pem /srv/docker/gitlab/gitlab/certs/

启用HTTPS

bash
docker run --name gitlab -d \
    --publish 10443:443 \
    --env 'SSL_SELF_SIGNED=true' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

维护

创建备份

bash
docker exec -it gitlab app:rake gitlab:backup:create

恢复备份

bash
docker exec -it gitlab app:rake gitlab:backup:restore BACKUP=1493107454_2017_04_25_11.0.2

自动化备份

设置BACKUP_SCHEDULE(cron格式)启用自动备份:

bash
docker run --name gitlab -d \
    --env 'BACKUP_SCHEDULE=0 1 * * *' \
    --env 'BACKUP_DIR=/home/git/data/backups' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

AWS远程备份

配置AWS S3备份:

bash
docker run --name gitlab -d \
    --env 'AWS_BACKUP=true' \
    --env 'AWS_ACCESS_KEY_ID=AKIAJ...' \
    --env 'AWS_SECRET_ACCESS_KEY=secret' \
    --env 'AWS_S3_BUCKET=my-gitlab-backups' \
    --volume /srv/docker/gitlab/gitlab:/home/git/data \
    sameersbn/gitlab:11.0.2

可用配置参数

参数描述
DB_ADAPTER数据库适配器(postgresql或mysql2)
DB_HOST数据库主机地址
DB_PORT数据库端口
DB_NAME数据库名称
DB_USER数据库用户名
DB_PASS数据库密码
REDIS_HOSTRedis主机地址
REDIS_PORTRedis端口
GITLAB_PORTHTTP访问端口
GITLAB_SSH_PORTSSH访问端口
GITLAB_SECRETS_OTP_KEY_BASE2FA加密密钥(至少64位)
GITLAB_SECRETS_DB_KEY_BASECI密钥加密密钥(至少64位)
GITLAB_SECRETS_SECRET_KEY_BASE密码重置等功能密钥(至少64位)
SMTP_*SMTP相关配置(USER、PASS、DOMAIN、HOST等)
IMAP_*IMAP相关配置(USER、PASS、HOST、PORT等)
SSL_SELF_SIGNED是否使用自签名SSL证书(true/false)
BACKUP_SCHEDULE自动备份cron表达式

特性

  • 容器仓库:集成Docker容器镜像仓库功能,支持私有镜像存储和管理

参考

  • GitLab官方文档
  • https://github.com/sameersbn/docker-gitlab
  • https://hub.docker.com/r/sameersbn/gitlab

查看更多 gitlab 相关镜像 →

GitLab (Archived) logo

mcp/gitlab

mcp(Model Context Protocol)
用于GitLab API的MCP服务器,支持项目管理、文件操作等功能,可通过Docker运行,提供安全的API交互能力。
25 次收藏1万+ 次下载
10 个月前更新
alpinelinux/gitlab logo

alpinelinux/gitlab

alpinelinux
基于Alpine Linux的轻量级Gitlab容器镜像,提供Git仓库管理、代码审查、CI/CD流水线等DevOps功能,适合资源受限环境部署。
13 次收藏1万+ 次下载
19 天前更新
okteto/gitlab logo

okteto/gitlab

okteto
暂无描述
3 次收藏2.3千+ 次下载
6 年前更新
gitlab/gitlab-runner logo

gitlab/gitlab-runner

gitlab
GitLab CI多Runner是GitLab CI/CD生态中的关键组件,主要用于通过GitLab CI系统自动获取并运行各类流水线作业,支持在多种环境中执行构建、测试、部署等软件开发流程中的关键步骤,助力团队实现自动化协作与高效交付。
994 次收藏10亿+ 次下载
12 天前更新
gitlab/gitlab-ce logo

gitlab/gitlab-ce

gitlab
GitLab社区版Docker镜像是基于Omnibus软件包构建的容器化部署方案,它整合了GitLab社区版的全部核心功能与必要依赖,通过Docker容器技术实现快速部署与便捷管理,适用于开发者和团队搭建自托管的Git仓库、进行代码管理、CI/CD流程自动化等场景,为开源项目和中小企业提供轻量高效的版本控制与协作平台。
4.4千 次收藏1亿+ 次下载
11 天前更新
gitlab/gitlab-ee logo

gitlab/gitlab-ee

gitlab
基于Omnibus软件包构建的GitLab企业版Docker镜像,其中Omnibus软件包集成了GitLab运行所需的各类核心组件(如Web服务器、数据库、缓存服务等),旨在通过容器化技术为企业用户提供便捷高效的部署方案,简化GitLab企业版的安装、配置与维护流程,满足企业在代码管理、CI/CD、项目协作等场景下的需求。
578 次收藏5000万+ 次下载
11 天前更新

轩辕镜像配置手册

探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式

Docker 配置

登录仓库拉取

通过 Docker 登录认证访问私有仓库

专属域名拉取

无需登录使用专属域名

K8s Containerd

Kubernetes 集群配置 Containerd

K3s

K3s 轻量级 Kubernetes 镜像加速

Dev Containers

VS Code Dev Containers 配置

Podman

Podman 容器引擎配置

Singularity/Apptainer

HPC 科学计算容器配置

其他仓库配置

ghcr、Quay、nvcr 等镜像仓库

Harbor 镜像源配置

Harbor Proxy Repository 对接专属域名

Portainer 镜像源配置

Portainer Registries 加速拉取

Nexus 镜像源配置

Nexus3 Docker Proxy 内网缓存

系统配置

Linux

在 Linux 系统配置镜像服务

Windows/Mac

在 Docker Desktop 配置镜像

MacOS OrbStack

MacOS OrbStack 容器配置

Docker Compose

Docker Compose 项目配置

NAS 设备

群晖

Synology 群晖 NAS 配置

飞牛

飞牛 fnOS 系统配置镜像

绿联

绿联 NAS 系统配置镜像

威联通

QNAP 威联通 NAS 配置

极空间

极空间 NAS 系统配置服务

网络设备

爱快路由

爱快 iKuai 路由系统配置

宝塔面板

在宝塔面板一键配置镜像

需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单

镜像拉取常见问题

使用与功能问题

配置了专属域名后,docker search 为什么会报错?

docker search 限制

Docker Hub 上有的镜像,为什么在轩辕镜像网站搜不到?

站内搜不到镜像

机器不能直连外网时,怎么用 docker save / load 迁镜像?

离线 save/load

docker pull 拉插件报错(plugin v1+json)怎么办?

插件要用 plugin install

WSL 里 Docker 拉镜像特别慢,怎么排查和优化?

WSL 拉取慢

轩辕镜像安全吗?如何用 digest 校验镜像没被篡改?

安全与 digest

第一次用轩辕镜像拉 Docker 镜像,要怎么登录和配置?

新手拉取配置

错误码与失败问题

docker pull 提示 manifest unknown 怎么办?

manifest unknown

docker pull 提示 no matching manifest 怎么办?

no matching manifest(架构)

镜像已拉取完成,却提示 invalid tar header 或 failed to register layer 怎么办?

invalid tar header(解压)

Docker pull 时 HTTPS / TLS 证书验证失败怎么办?

TLS 证书失败

Docker pull 时 DNS 解析超时或连不上仓库怎么办?

DNS 超时

Docker 拉取出现 410 Gone 怎么办?

410 Gone 排查

出现 402 或「流量用尽」提示怎么办?

402 与流量用尽

Docker 拉取提示 UNAUTHORIZED(401)怎么办?

401 认证失败

遇到 429 Too Many Requests(请求太频繁)怎么办?

429 限流

docker login 提示 Cannot autolaunch D-Bus,还算登录成功吗?

D-Bus 凭证提示

为什么会出现「单层超过 20GB」或 413,无法加速拉取?

413 与超大单层

账号 / 计费 / 权限

轩辕镜像免费版和专业版有什么区别?

免费版与专业版区别

轩辕镜像支持哪些 Docker 镜像仓库?

支持的镜像仓库

镜像拉取失败还会不会扣流量?

失败是否计费

麒麟 V10 / 统信 UOS 提示 KYSEC 权限不够怎么办?

KYSEC 拦截脚本

如何在轩辕镜像申请开具发票?

申请开票

怎么修改轩辕镜像的网站登录和仓库登录密码?

修改登录密码

如何注销轩辕镜像账户?要注意什么?

注销账户

配置与原理类

写了 registry-mirrors,为什么还是走官方或仍然报错?

mirrors 不生效

怎么用 docker tag 去掉镜像名里的轩辕域名前缀?

去掉域名前缀

如何拉取指定 CPU 架构的镜像(如 ARM64、AMD64)?

指定架构拉取

用轩辕镜像拉镜像时快时慢,常见原因有哪些?

拉取速度原因

查看全部问题→

用户好评

来自真实用户的反馈,见证轩辕镜像的优质服务

用户头像

oldzhang

运维工程师

Linux服务器

5

"Docker访问体验非常流畅,大镜像也能快速完成下载。"

轩辕镜像
镜像详情
...
yuankunzhang/gitlab
博客公告Docker 镜像公告与技术博客
热门镜像查看热门 Docker 镜像推荐
一键安装一键安装 Docker 并配置镜像源
镜像拉取问题咨询请 提交工单,官方技术交流群:1072982923。轩辕镜像所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
镜像拉取问题咨询请提交工单,官方技术交流群:。轩辕镜像所有镜像均来源于原始仓库,本站不存储、不修改、不传播任何镜像内容。
商务合作:点击复制邮箱
©2024-2026 源码跳动
商务合作:点击复制邮箱Copyright © 2024-2026 杭州源码跳动科技有限公司. All rights reserved.