
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本镜像基于GitLab CE 11.7.0版本构建,采用官方源码安装方式,为Docker环境提供企业级代码托管平台。支持团队协作开发、版本控制、CI/CD流程及项目管理等核心功能,适用于企业私有仓库或开源项目托管场景。
为避免数据丢失,需挂载卷到容器内/home/git/data路径:
bashmkdir -p /srv/docker/gitlab/gitlab # SELinux用户需执行:sudo chcon -Rt svirt_sandbox_file_t /srv/docker/gitlab/gitlab
PostgreSQL(推荐)
外部PostgreSQL服务器:
bashdocker 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 \ gitlab:11.7.0
链接PostgreSQL容器:
bash# 启动PostgreSQL容器 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 \ postgres:10 # 启动GitLab并链接 docker run --name gitlab -d --link gitlab-postgresql:postgresql \ --volume /srv/docker/gitlab/gitlab:/home/git/data \ gitlab:11.7.0
MySQL
外部MySQL服务器:
bashdocker 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 \ gitlab:11.7.0
链接Redis容器:
bash# 启动Redis容器 docker run --name gitlab-redis -d \ --volume /srv/docker/gitlab/redis:/var/lib/redis \ redis:4.0.9-1 # 启动GitLab并链接 docker run --name gitlab -d --link gitlab-redis:redisio \ gitlab:11.7.0
SMTP发送邮件(Gmail示例):
bashdocker run --name gitlab -d \ --env 'SMTP_USER=user@gmail.com' --env 'SMTP_PASS=password' \ --volume /srv/docker/gitlab/gitlab:/home/git/data \ gitlab:11.7.0
启用HTTPS(自签名证书示例):
bashopenssl genrsa -out gitlab.key 2048 openssl req -new -key gitlab.key -out gitlab.csr openssl x509 -req -days 3650 -in gitlab.csr -signkey gitlab.key -out gitlab.crt openssl dhparam -out dhparam.pem 2048
bashmkdir -p /srv/docker/gitlab/gitlab/certs cp gitlab.key gitlab.crt dhparam.pem /srv/docker/gitlab/gitlab/certs/ chmod 400 /srv/docker/gitlab/gitlab/certs/gitlab.key
bashdocker run --name gitlab -d \ --publish 10022:22 --publish 10443:443 \ --env 'GITLAB_SSH_PORT=10022' --env 'GITLAB_PORT=10443' \ --env 'GITLAB_HTTPS=true' --env 'SSL_SELF_SIGNED=true' \ --volume /srv/docker/gitlab/gitlab:/home/git/data \ gitlab:11.7.0
bashwget https://raw.githubusercontent.com/dockerimages/gitlab/master/docker-compose.yml
bashexport GITLAB_SECRETS_OTP_KEY_BASE=$(pwgen -Bsv1 64) export GITLAB_SECRETS_DB_KEY_BASE=$(pwgen -Bsv1 64) export GITLAB_SECRETS_SECRET_KEY_BASE=$(pwgen -Bsv1 64)
bashdocker-compose up -d
bashdocker 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=your-long-secret' \ --env 'GITLAB_SECRETS_SECRET_KEY_BASE=your-long-secret' \ --env 'GITLAB_SECRETS_OTP_KEY_BASE=your-long-secret' \ --volume /srv/docker/gitlab/gitlab:/home/git/data \ gitlab:11.7.0
访问http://localhost:10080(或HTTPS的https://localhost:10443),设置root用户密码即可使用。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务