'Ubuntu系统搭建企业级GitLab高可用主备代码仓库完整指南'
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官方参考架构进行分层部署。
相关文章
评论