blogInvalid Date· 约 33 分钟

'Ubuntu系统搭建企业级GitLab高可用主备代码仓库完整指南'

Twitter 微博

Ubuntu系统搭建企业级GitLab高可用主备代码仓库完整指南

一、架构选型与规划#

1.1 高可用主备架构方案#

企业级GitLab高可用部署主要有以下几种主流方案:

方案一:DRBD + Pacemaker + Corosync(主备模式)

该架构为Active/Passive(主/备)模式,只有主节点运行GitLab服务并挂载存储,备节点通过DRBD实时同步数据。当主节点宕机时,Pacemaker自动将VIP和存储切换到备节点。此方案适合中小型企业,硬件成本低,约比单节点增加40%。

方案二:GitLab Geo(地理分布式)

GitLab企业版(EE)原生提供的Geo功能,可实现完整的实例级复制。主站点可读写,辅助站点只读,支持自动故障转移。需要GitLab Premium或Ultimate订阅。

方案三:分层高可用架构(官方参考架构)

将GitLab各组件拆分部署:前端负载均衡(HAProxy/Nginx)+ 多个GitLab应用节点 + PostgreSQL集群(Patroni+etcd)+ Redis Sentinel + 共享存储(NFS/Ceph)。适合大规模企业。

本文推荐方案一(DRBD + Pacemaker) ,性价比高、部署相对简单,适合大多数企业场景。如团队规模超过200人,建议升级到方案三。

1.2 硬件配置建议#

团队规模

CPU

内存

存储

网络

5-20人

4核

8GB

100GB SSD

100Mbps

20-100人

8核

16GB

500GB NVMe SSD

1Gbps

100人以上

16核+

32GB+

RAID10 SSD阵列

多网卡绑定

⚠️ 生产环境强烈建议使用SSD存储,GitLab官方建议禁用swap分区。

1.3 服务器规划示例#

角色

主机名

IP地址

配置

主节点

gitlab-primary

192.168.1.10

8核16G + 500GB SSD

备节点

gitlab-secondary

192.168.1.11

8核16G + 500GB SSD

虚拟IP(VIP)

gitlab.local

192.168.1.100

浮动IP

二、基础环境准备(两台节点均需执行)#

2.1 系统更新与依赖安装#

bash

# 更新系统 sudo apt update && sudo apt upgrade -y

# 安装必要依赖 sudo apt install -y \ curl \ openssh-server \ ca-certificates \ tzdata \ perl \ postfix \ wget \ gnupg \ lsb-release \ software-properties-common

安装postfix时,如选择“Internet Site”,输入你的邮件域名;如暂不需要邮件功能可跳过。

2.2 配置防火墙#

bash

sudo ufw allow 22/tcp # SSH访问 sudo ufw allow 80/tcp # HTTP服务 sudo ufw allow 443/tcp # HTTPS服务 sudo ufw allow 9090/tcp # Prometheus监控(可选) sudo ufw enable

2.3 系统优化配置#

bash

# 禁用swap(GitLab官方建议) sudo swapoff -a sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab

# 配置时区 sudo timedatectl set-timezone Asia/Shanghai

# 优化系统文件句柄限制 echo "fs.file-max = 65536" | sudo tee -a /etc/sysctl.conf sudo sysctl -p

2.4 配置SSH免密登录(主备节点间)#

bash

# 在主节点生成SSH密钥 ssh-keygen -t rsa -b 4096 -N "" -f ~/.ssh/id_rsa

# 将公钥复制到备节点 ssh-copy-id root@192.168.1.11

# 同样在备节点生成并复制到主节点 ssh-keygen -t rsa -b 4096 -N "" -f ~/.ssh/id_rsa ssh-copy-id root@192.168.1.10

三、安装GitLab#

3.1 添加GitLab官方仓库#

使用官方源(国外服务器较快):

bash

curl -sS https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh | sudo bash

使用国内清华镜像源(推荐国内用户):

bash

# 信任GitLab GPG公钥 curl -fsSL https://packages.gitlab.com/gpg.key | sudo gpg --dearmor -o /usr/share/keyrings/gitlab_gitlab-ee-archive-keyring.gpg

# 添加源 echo "deb [signed-by=/usr/share/keyrings/gitlab_gitlab-ee-archive-keyring.gpg] https://mirrors.tuna.tsinghua.edu.cn/gitlab-ee/ubuntu $(lsb_release -cs) main" | sudo tee /etc/apt/sources.list.d/gitlab-ee.list

sudo apt update

💡 如使用社区版(CE),将上述命令中的gitlab-ee替换为gitlab-ce。企业版(EE)提供更多高可用特性,生产环境建议使用企业版。

3.2 安装GitLab#

bash

# 安装企业版(设置外部访问URL) sudo EXTERNAL_URL="https://gitlab.local" apt-get install -y gitlab-ee

如果尚未配置域名和SSL证书,可先使用IP地址:EXTERNAL_URL="http://192.168.1.10"

3.3 初始配置#

bash

# 编辑主配置文件 sudo vim /etc/gitlab/gitlab.rb

基础配置项:

ruby

# 外部访问地址 external_url 'https://gitlab.local'

# 时区 gitlab_rails['time_zone'] = 'Asia/Shanghai'

# 数据存储目录(后续将迁移到共享存储) git_data_dirs({ "default" => { "path" => "/var/opt/gitlab/git-data" } })

# 邮件配置(可选) gitlab_rails['smtp_enable'] = true gitlab_rails['smtp_address'] = "smtp.your-email.com" gitlab_rails['smtp_port'] = 587 gitlab_rails['smtp_user_name'] = "gitlab@your-email.com" gitlab_rails['smtp_password'] = "your-password" gitlab_rails['smtp_domain'] = "your-email.com" gitlab_rails['smtp_authentication'] = "login" gitlab_rails['smtp_enable_starttls_auto'] = true gitlab_rails['gitlab_email_from'] = 'gitlab@your-email.com'

3.4 应用配置并启动#

bash

sudo gitlab-ctl reconfigure

该命令会启动所有必要服务,耗时几分钟。

3.5 验证安装#

bash

# 查看服务状态 sudo gitlab-ctl status

# 获取初始root密码 sudo cat /etc/gitlab/initial_root_password

四、高可用核心组件配置#

4.1 配置共享存储(DRBD)#

DRBD实现两台服务器间数据的实时块级同步。

在两台节点上安装DRBD:

bash

sudo apt install -y drbd-utils

在主节点创建DRBD配置文件:

bash

sudo vim /etc/drbd.d/gitlab.res

conf

resource gitlab { protocol C; meta-disk internal;

device /dev/drbd0;
disk /dev/sdb;  class=class="hljs-string">"hljs-comment"># 请替换为实际的数据盘设备

net {
    cram-hmac-alg sha1;
    shared-secret class="hljs-string">"your-secure-secret-key";
}

on gitlab-primary {
    address class="hljs-number">192.168.class="hljs-number">1.10:class="hljs-number">7789;
}

on gitlab-secondary {
    address class="hljs-number">192.168.class="hljs-number">1.11:class="hljs-number">7789;
}

}

初始化DRBD资源(两台节点执行):

bash

# 创建元数据 sudo drbdadm create-md gitlab

# 启动DRBD服务 sudo systemctl enable drbd sudo systemctl start drbd

# 在主节点提升为Primary sudo drbdadm primary --force gitlab

# 创建文件系统(仅在主节点执行) sudo mkfs.ext4 /dev/drbd0

# 挂载存储 sudo mkdir -p /mnt/gitlab-data sudo mount /dev/drbd0 /mnt/gitlab-data

配置自动挂载:

bash

echo '/dev/drbd0 /mnt/gitlab-data ext4 defaults,noatime 0 0' | sudo tee -a /etc/fstab

4.2 配置GitLab使用共享存储#

修改GitLab数据目录:

bash

sudo vim /etc/gitlab/gitlab.rb

ruby

# 将数据目录指向共享存储 git_data_dirs({ "default" => { "path" => "/mnt/gitlab-data/git-data" } })

# 仓库存储路径 gitlab_rails['repository_storage_dirs'] = { "default" => "/mnt/gitlab-data/git-data/repositories" }

# 上传文件存储 gitlab_rails['uploads_directory'] = "/mnt/gitlab-data/uploads"

迁移现有数据到共享存储(如已存在数据):

bash

# 停止GitLab服务 sudo gitlab-ctl stop

# 迁移数据 sudo rsync -av /var/opt/gitlab/ /mnt/gitlab-data/

# 重新配置并启动 sudo gitlab-ctl reconfigure sudo gitlab-ctl start

4.3 配置PostgreSQL高可用(Patroni + etcd)#

GitLab官方推荐使用Patroni + etcd实现PostgreSQL自动主备切换。

在两台节点安装etcd和Patroni:

bash

sudo apt install -y etcd patroni patroni-pgq

配置etcd集群(两台节点):

bash

sudo vim /etc/default/etcd

主节点配置:

conf

ETCD_NAME="etcd1" ETCD_INITIAL_ADVERTISE_PEER_URLS="http://192.168.1.10:2380" ETCD_LISTEN_PEER_URLS="http://0.0.0.0:2380" ETCD_LISTEN_CLIENT_URLS="http://0.0.0.0:2379" ETCD_ADVERTISE_CLIENT_URLS="http://192.168.1.10:2379" ETCD_INITIAL_CLUSTER="etcd1=http://192.168.1.10:2380,etcd2=http://192.168.1.11:2380" ETCD_INITIAL_CLUSTER_STATE="new"

备节点将IP替换为192.168.1.11,ETCD_NAME改为etcd2

启动etcd:

bash

sudo systemctl enable etcd sudo systemctl start etcd

配置Patroni:

bash

sudo vim /etc/patroni/patroni.yml

yaml

scope: gitlab name: gitlab-pg-1 # 主节点为1,备节点为2

restapi: listen: 0.0.0.0:8008 connect_address: 192.168.1.10:8008 # 备节点改为备节点IP

etcd: hosts: - 192.168.1.10:2379 - 192.168.1.11:2379

bootstrap: dcs: ttl: 30 loop_wait: 10 retry_timeout: 10 maximum_lag_on_failover: 1048576 postgresql: use_pg_rewind: true parameters: max_connections: 200 shared_buffers: 256MB wal_level: replica hot_standby: "on" max_wal_senders: 10 max_replication_slots: 10 wal_log_hints: "on"

postgresql: listen: 0.0.0.0:5432 connect_address: 192.168.1.10:5432 # 备节点改为备节点IP data_dir: /mnt/gitlab-data/postgresql pgpass: /tmp/pgpass authentication: replication: username: replicator password: your-replica-password superuser: username: postgres password: your-superuser-password parameters: unix_socket_directories: /var/run/postgresql

启动Patroni:

bash

sudo systemctl enable patroni sudo systemctl start patroni

配置GitLab使用外部PostgreSQL:

ruby

# /etc/gitlab/gitlab.rb postgresql['enable'] = false gitlab_rails['db_host'] = '192.168.1.10' # 或使用VIP gitlab_rails['db_port'] = 5432 gitlab_rails['db_username'] = 'gitlab' gitlab_rails['db_password'] = 'gitlab-db-password' gitlab_rails['db_database'] = 'gitlabhq_production'

4.4 配置Redis高可用(Redis Sentinel)#

安装Redis(两台节点):

bash

sudo apt install -y redis-server

配置Redis主从:

主节点 /etc/redis/redis.conf

conf

bind 0.0.0.0 port 6379 requirepass your-redis-password masterauth your-redis-password

备节点 /etc/redis/redis.conf

conf

bind 0.0.0.0 port 6379 requirepass your-redis-password masterauth your-redis-password replicaof 192.168.1.10 6379

配置Redis Sentinel(两台节点):

bash

sudo vim /etc/redis/sentinel.conf

conf

bind 0.0.0.0 port 26379 sentinel monitor gitlab-redis 192.168.1.10 6379 2 sentinel auth-pass gitlab-redis your-redis-password sentinel down-after-milliseconds gitlab-redis 5000 sentinel failover-timeout gitlab-redis 60000

启动服务:

bash

sudo systemctl enable redis-server redis-sentinel sudo systemctl start redis-server redis-sentinel

配置GitLab使用Redis Sentinel:

ruby

# /etc/gitlab/gitlab.rb redis['enable'] = false gitlab_rails['redis_host'] = '192.168.1.10' gitlab_rails['redis_port'] = 6379 gitlab_rails['redis_password'] = 'your-redis-password'

4.5 配置负载均衡与VIP漂移(Keepalived)#

安装Keepalived(两台节点):

bash

sudo apt install -y keepalived

主节点配置 /etc/keepalived/keepalived.conf

conf

vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 51 priority 100 advert_int 1 authentication { auth_type PASS auth_pass your-auth-password } virtual_ipaddress { 192.168.1.100/24 dev eth0 } track_script { check_gitlab } }

vrrp_script check_gitlab { script "/usr/local/bin/check_gitlab.sh" interval 5 weight -10 }

备节点配置(state改为BACKUP,priority改为90)。

健康检查脚本 /usr/local/bin/check_gitlab.sh

bash

#!/bin/bash if curl -s -o /dev/null -w "%{http_code}" http://localhost:80/ | grep -q "200\|302"; then exit 0 else exit 1 fi

bash

sudo chmod +x /usr/local/bin/check_gitlab.sh sudo systemctl enable keepalived sudo systemctl start keepalived

4.6 配置Nginx负载均衡(可选)#

如需在前端增加负载均衡层:

bash

sudo apt install -y nginx

nginx

# /etc/nginx/sites-available/gitlab upstream gitlab_backend { server 192.168.1.10:80 max_fails=3 fail_timeout=30s; server 192.168.1.11:80 max_fails=3 fail_timeout=30s backup; keepalive 32; }

server { listen 80; server_name gitlab.local;

location / {
    proxy\_pass http:class=class="hljs-string">"hljs-comment">//gitlab\_backend;
    proxy\_set\_header Host $host;
    proxy\_set\_header X-Real-IP $remote\_addr;
    proxy\_set\_header X-Forwarded-For $proxy\_add\_x\_forwarded\_for;
    proxy\_set\_header X-Forwarded-Proto $scheme;
    proxy\_http\_version class="hljs-number">1.1;
    proxy\_set\_header Connection class="hljs-string">"";
}

}

五、配置SSL证书(HTTPS)#

5.1 使用Let's Encrypt免费证书#

bash

sudo apt install -y certbot python3-certbot-nginx

# 申请证书(需已配置域名解析) sudo certbot certonly --nginx -d gitlab.yourdomain.com

# 自动续期 echo "0 3 * * * root /usr/bin/certbot renew --quiet" | sudo tee /etc/cron.d/certbot-renew

5.2 配置GitLab使用SSL#

ruby

# /etc/gitlab/gitlab.rb external_url 'https://gitlab.yourdomain.com'

nginx['redirect_http_to_https'] = true nginx['ssl_certificate'] = "/etc/letsencrypt/live/gitlab.yourdomain.com/fullchain.pem" nginx['ssl_certificate_key'] = "/etc/letsencrypt/live/gitlab.yourdomain.com/privkey.pem" nginx['ssl_protocols'] = "TLSv1.2 TLSv1.3"

六、监控与告警配置#

6.1 启用GitLab内置监控#

ruby

# /etc/gitlab/gitlab.rb prometheus['enable'] = true prometheus['listen_address'] = '0.0.0.0:9090'

node_exporter['enable'] = true node_exporter['listen_address'] = '0.0.0.0:9100'

redis_exporter['enable'] = true redis_exporter['listen_address'] = '0.0.0.0:9121'

postgres_exporter['enable'] = true postgres_exporter['listen_address'] = '0.0.0.0:9187'

gitlab_exporter['enable'] = true gitlab_exporter['listen_address'] = '0.0.0.0:9168'

6.2 安装Grafana可视化#

bash

sudo apt install -y grafana sudo systemctl enable grafana-server sudo systemctl start grafana-server

访问 http://gitlab.local:3000,添加Prometheus数据源,导入GitLab官方仪表盘。

6.3 关键告警阈值#

建议设置以下告警:

  • PostgreSQL连接数 > 最大值的80%

  • Redis内存使用 > 8GB

  • 仓库存储空间 > 90%

  • Sidekiq队列积压 > 1000

  • HTTP 500错误率 > 1%

七、备份策略#

7.1 定期备份#

bash

# 创建完整备份 sudo gitlab-rake gitlab:backup:create

# 备份配置文件 sudo tar -czf /mnt/gitlab-data/backups/gitlab-config-$(date +%Y%m%d).tar.gz /etc/gitlab/

7.2 自动化备份脚本#

bash

#!/bin/bash # /usr/local/bin/gitlab-backup.sh

BACKUP_DIR="/mnt/gitlab-data/backups" DATE=$(date +%Y%m%d_%H%M%S)

# 创建备份 sudo gitlab-rake gitlab:backup:create

# 备份配置文件 sudo tar -czf ${BACKUP_DIR}/gitlab-config-${DATE}.tar.gz /etc/gitlab/

# 保留最近7天的备份 find ${BACKUP_DIR} -name "*.tar" -mtime +7 -delete find ${BACKUP_DIR} -name "*.tar.gz" -mtime +7 -delete

bash

# 添加到crontab(每天凌晨2点执行) echo "0 2 * * * /usr/local/bin/gitlab-backup.sh" | sudo tee -a /etc/crontab

八、故障转移与恢复#

8.1 手动故障转移(主节点故障时)#

bash

# 在备节点上 # 1. 提升DRBD为Primary sudo drbdadm primary gitlab

# 2. 挂载存储 sudo mount /dev/drbd0 /mnt/gitlab-data

# 3. 启动GitLab sudo gitlab-ctl start

# 4. 提升Keepalived为MASTER(或等待自动切换) sudo systemctl restart keepalived

8.2 自动故障转移#

通过Keepalived + DRBD + Pacemaker组合可实现自动故障转移。配置Pacemaker资源管理:

bash

sudo apt install -y pacemaker corosync

# 配置Corosync集群 sudo vim /etc/corosync/corosync.conf

# 添加资源:VIP、DRBD、GitLab服务 sudo pcs resource create gitlab-vip IPaddr2 ip=192.168.1.100 sudo pcs resource create gitlab-drbd drbd ... sudo pcs resource create gitlab-service systemd:gitlab-runsvdir

九、运维管理要点#

9.1 日常巡检命令#

bash

# 查看GitLab服务状态 sudo gitlab-ctl status

# 查看日志 sudo gitlab-ctl tail

# 查看DRBD同步状态 sudo drbdadm status gitlab

# 查看集群状态 sudo pcs status

# 查看Keepalived状态 sudo systemctl status keepalived

9.2 版本升级#

bash

# 停止GitLab(生产环境建议在维护窗口进行) sudo gitlab-ctl stop unicorn sudo gitlab-ctl stop sidekiq

# 更新包 sudo apt update sudo apt install --only-upgrade gitlab-ee

# 重新配置 sudo gitlab-ctl reconfigure sudo gitlab-ctl restart

9.3 安全加固建议#

  • 启用2FA双因素认证

  • 配置IP白名单限制管理访问

  • 禁用默认root账户登录

  • 定期更新系统与GitLab版本

  • 启用审计日志

十、部署检查清单#

检查项

状态

两台节点系统环境一致

SSH免密登录配置完成

DRBD数据同步正常

PostgreSQL主从复制正常

Redis Sentinel集群正常

VIP漂移测试通过

SSL证书配置生效

备份脚本测试通过

监控告警配置完成

故障转移演练完成


以上是完整的Ubuntu系统企业级GitLab高可用主备部署指南。建议在正式上线前,在测试环境完整演练一遍部署流程和故障切换场景。如团队规模超过200人,建议参考GitLab官方参考架构进行分层部署。

评论

© 2026 松岛川树