当前位置: 首页 > news >正文

本地自建 Gitlab 服务(支持 SSH + Registry + Pages 完整功能)

最终效果

image
image

背景介绍

因为 Gitlab 中国区新版本已经由国内的极狐接管,迫于使用习惯,我们还是使用原汁原味的 Gitlab 官方维护的版本,这里使用的版本是 15.11.13,因为新的 UI 实在是显得太臃肿了,我们使用 Docker 来部署,需要准备的内容有:

  1. gitlab.xxx.xxx 域名(需要解析到 gitlab.xxx.xxx 到 Nginx IP)
  2. pages.xxx.xxx 域名(需要解析 *.pages.xxx.xxx 到 Nginx IP)
  3. 外部 Nginx (用来实现 SSL 访问,容器内部做太过于麻烦,解耦开)
  4. SSL证书(可以使用购买的证书或者是使用免费的 let'sencrypt,实际上是支持通配符的)
  5. Docker

部署方法

1. 解析配置

首先在域名解析的地方解析域名,为了方便(因为我的 Nginx 还承载了其他服务)直接解析 * 的通配符域名到我们的 Nginx
image

2. Nginx 配置

接下来解析我们的 gitlab 到真实服务地址,请注意有三个服务(分别是gitlab主站、registry镜像服务、pages静态网页服务)
image
image
image
需要注意的是需要在自定义设置中配置优化选项例如缓存、WS支持、SSL等,以及还需要添加自定的块,我使用 nginx proxy manager 演示
image
image
请注意每个规则的自定义配置部分都需要添加

proxy_set_header X-Forwarded-Proto  https;
proxy_set_header X-Forwarded-Ssl    on;
proxy_set_header X-Real-IP          $remote_addr;
proxy_set_header X-Forwarded-For    $proxy_add_x_forwarded_for;
proxy_set_header Host               $http_host;

image

3. gitlab 配置

编写 docker-compose.yaml 文件

services:gitlab:image: 'gitlab/gitlab-ee:15.11.13-ee.0'container_name: gitlabrestart: alwayshostname: 'gitlab.xxx.xxx'environment:GITLAB_OMNIBUS_CONFIG: |external_url 'https://gitlab.xxx.xxx'nginx['listen_port'] = 80nginx['listen_https'] = falsenginx['redirect_http_to_https'] = falseletsencrypt['enable'] = falsenginx['proxy_set_headers'] = {"X-Forwarded-Proto" => "https","X-Forwarded-Ssl"   => "on","X-Real-IP"         => "$$remote_addr","X-Forwarded-For"   => "$$proxy_add_x_forwarded_for","Host"              => "$$http_host"}gitlab_rails['trusted_proxies'] = ['10.0.0.0/8', '172.16.0.0/12', '192.168.0.0/16']gitlab_rails['gitlab_shell_ssh_port'] = 2222registry_external_url 'https://registry.xxx.xxx'registry['enable'] = trueregistry_nginx['listen_port'] = 80registry_nginx['listen_https'] = falseregistry_nginx['proxy_set_headers'] = {"X-Forwarded-Proto" => "https","X-Forwarded-Ssl"   => "on"}pages_external_url 'https://pages.xxx.xxx'gitlab_pages['enable'] = truegitlab_pages['internal_gitlab_server'] = 'http://gitlab.xxx.xxx'gitlab_pages['artifacts_server_url'] = 'http://gitlab.xxx.xxx'pages_nginx['listen_port'] = 80pages_nginx['listen_https'] = falsepages_nginx['proxy_set_headers'] = {"X-Forwarded-Proto" => "https","X-Forwarded-Ssl"   => "on"}prometheus_monitoring['enable'] = falsegitlab_rails['time_zone'] = 'Asia/Shanghai'puma['worker_processes'] = 2sidekiq['concurrency'] = 10postgresql['shared_buffers'] = "256MB"## ─── Email / SMTP ────────────────────────────────────────────# gitlab_rails['smtp_enable'] = true# gitlab_rails['smtp_address'] = "smtp.example.com"# gitlab_rails['smtp_port'] = 587# gitlab_rails['smtp_user_name'] = "user@example.com"# gitlab_rails['smtp_password'] = "smtp_password"# gitlab_rails['smtp_domain'] = "example.com"# gitlab_rails['smtp_authentication'] = "login"# gitlab_rails['smtp_enable_starttls_auto'] = true# gitlab_rails['gitlab_email_from'] = "gitlab@example.com"ports:- '2222:22'      # SSH clone / push- '18080:80'     # HTTP(由外部的 Nginx 代理到这个端口,处理 SSL)volumes:- './gitlab/config:/etc/gitlab'- './gitlab/logs:/var/log/gitlab'- './gitlab/data:/var/opt/gitlab'shm_size: '256m'healthcheck:test: ["CMD", "/opt/gitlab/bin/gitlab-healthcheck", "--fail", "--max-time", "10"]interval: 60stimeout: 30sretries: 5start_period: 5m

4. 启动并访问

直接docker compose pull && docker compose up -d启动等待几分钟后使用初始密码访问网页即可,初始密码获取方式

docker exec gitlab cat /etc/gitlab/initial_root_password 2>/dev/null | grep Password

参考资料

  1. https://todoit.tech/k8s/gitlab/
  2. https://www.hash070.top/archives/gitlab-ee-crack.html
  3. https://pengtech.net/gitlab/gitlab_ee_crack.html
  4. https://soulteary.com/2021/07/14/gitlab-14-lightweight-operation-solution.html
http://www.gsyq.cn/news/1470106.html

相关文章:

  • 2026 禅城防水补漏推荐,本土直营苏易修缮,老城区岭南民居 / 季华商圈商铺就近上门修漏水 - 苏易修缮
  • 【实操解决 OpenClaw】 无法操作本机,管理员权限与安全设置指南(含安装包
  • 2026义乌日本双清包税优质服务商推荐推荐 - 优质品牌商家
  • 告别SIAR!在R中快速上手SIMMR进行稳定同位素混合建模:安装、常见报错与可视化避坑指南
  • 编程语言什么是c语言
  • 普宁全屋定制品牌排名|本地有口碑的全屋定制品牌有哪些 - 品牌观察
  • 2026年新消息发布:嘉兴市汽车功放服务商专业度全景解析 - 2026年企业资讯
  • 【变压器的短路试验】变压器的短路试验是通过将二次侧短路,并向一次侧施加额定电流来进行附Simulink仿真
  • 2026年沈阳漏水维修服务商盘点:为何沈阳市沈河区马上到家防水科技中心备受推崇? - 2026年企业资讯
  • Mac百度网盘SVIP完整解决方案:突破限速瓶颈的终极实践手册
  • 告别Android屏幕适配烦恼:AutoSize框架实战指南
  • 终极指南:使用Python密钥生成器解锁Beyond Compare 5完整功能
  • 项目汇报PPT模板哪家强?2026全网实测,职场人直接抄作业! - 品牌测评鉴赏家
  • 35:机台对接典型场景1:开机联网全流程
  • 靠谱的耐腐蚀合金生产厂家有哪些 - myqiye
  • 2026年EB-5移民机构排名及选择参考 - 品牌排行榜
  • 微量样本最大化利用!云克隆多因子检测试剂盒,助力呼吸系统疾病机制研究
  • 告别重复造轮子:快马一键生成jupyter notebook高效数据分析模板
  • 12903黄大年茶思屋榜文第129期 第3题:支持增量更新的低存储、低功耗端侧向量索引技术
  • 【Veo 2帧率优化黄金法则】:20年视频引擎专家亲授3种实测有效设置,错过再等半年!
  • 2026年太原墙布窗帘服务品牌综合排行盘点 - 优质品牌商家
  • 2026年市电路灯推荐:江苏智韵照明靠谱吗? - myqiye
  • 犬脑星形胶质细胞(BA)原代细胞制备方案 云克隆提供优质犬细胞
  • 现货耐腐蚀合金带材哪家企业性价比高? - myqiye
  • STM32F103C8T6硬件SPI直驱ST7789彩屏的Keil工程包(含初始化、横竖屏切换与绘图函数)
  • 12904黄大年茶思屋榜文第129期 第4题:视窗2D引擎运行时GPU管线Shader创建编译零卡顿
  • 决定TVA毫秒级响应上限的关键层级解析
  • SQL数据查询实战:在数据海洋中精准捞取所需的艺术
  • 破解安卓SSL证书绑定难题:r0capture动态插桩抓包技术深度解析
  • 电动伸缩门厂家直销上门安装 - myqiye