使用 `glab` 管理多个内网 GitLab 实例:配置详解与合并请求自动化


作者:机智的爆爆哥

环境:macOS + GitLab Self-Managed(多 IP 内网部署)

工具:glab(GitLab 官方 CLI)

在企业开发中,我们常常会遇到 多个 GitLab 实例 的场景:测试环境、预发环境、生产环境分别部署在不同 IP 上。此时,如何用命令行高效管理这些仓库?git 命令本身不支持 API 操作(如创建 Merge Request),而 glab(GitLab CLI)正是官方推出的解决方案。

本文将手把手教你:

  • 安装 glab
  • 配置多 GitLab 实例(含非标准端口)
  • 自动生成 git mrc 别名,一键创建 MR
  • 避开常见坑点(如 GITLAB_HOST 环境变量干扰)

🔒 安全提示:文中所有 IP 和 Token 均已脱敏,请替换为你自己的实际值。


一、安装 glab

macOS(推荐使用 Homebrew):

bash 复制代码
brew install glab

验证安装:

bash 复制代码
glab --version
# 输出示例:glab version 1.32.0 (2024-12-09)

二、配置多 GitLab 实例(关键!)

glab 的配置文件默认位于:

bash 复制代码
~/Library/Application Support/glab-cli/config.yml

⚠️ 重要不要 在 Shell 环境中设置 GITLAB_HOST

该变量会强制覆盖自动识别逻辑,导致"remote 不匹配"错误。

✅ 正确配置示例(支持 3 个内网 GitLab):

yaml 复制代码
git_protocol: http
editor:
browser:
glamour_style: dark
check_update: false
display_hyperlinks: false
no_prompt: false
telemetry: true

# 关键:不要设置全局 host!让 glab 自动从 remote 匹配
# host: GITLAB_IP_1  # ← 注释掉这行!

hosts:
  # === GitLab 1: 标准 HTTP 80 端口 ===
  GITLAB_IP_1:
    token: YOUR_TOKEN_1
    api_protocol: http
    api_host: GITLAB_IP_1
    git_protocol: http
    container_registry_domains: []

  # === GitLab 2: 非标准端口(如 8099)===
  GITLAB_IP_2:
    token: YOUR_TOKEN_2
    api_protocol: http
    api_host: GITLAB_IP_2:8099  # ← 端口写在这里
    git_protocol: http
    container_registry_domains: []

  # === GitLab 3: 另一个内网实例 ===
  GITLAB_IP_3:
    token: YOUR_TOKEN_3
    api_protocol: http
    api_host: GITLAB_IP_3
    git_protocol: http
    container_registry_domains: []

🔑 配置要点:

项目 说明
hosts 键名 必须是 纯 IP (如 192.168.x.x),不能带端口或 /
api_host 可带端口(如 172.16.x.x:8099
token 在对应 GitLab 实例的 Personal Access Tokens 页面创建,需勾选 api + write_repository
git_protocol 必须与你 git clone 时用的协议一致(本文均为 http
全局 host 字段 建议注释掉 ,让 glab 自动从 remote URL 识别

三、创建 Personal Access Token

在每个 GitLab 实例上操作:

  1. 登录 → 点击头像 → Edit profile
  2. 左侧菜单 → Personal Access Tokens
  3. 创建新 Token:
    • Name: glab-cli
    • Scopes: ✅ api + ✅ write_repository
    • Expiry: 建议 365 天
  4. 复制生成的 Token(只显示一次!)

📌 Token 权限说明:

  • api:允许调用 GitLab API(包括创建 MR)
  • write_repository:允许通过 HTTP 推送代码

四、设置 git mrc 别名(一键创建 MR)

在终端执行:

bash 复制代码
git config --global alias.mrc '!f() { \
    glab mr create \
    --source-branch "$1" \
    --target-branch "$2" \
    --title "Git合并: $1 -> $2" \
    --description "命令行创建的合并请求" \
    --yes; \
}; f'

使用方式:

bash 复制代码
# 创建从 feature-xxx 到 dev 的合并请求
git mrc feature-xxx dev

# 创建从 xx 到 test 的合并请求
git mrc xx test

--yes 自动跳过交互确认,适合脚本化。


五、常见问题排查

❌ 报错:

复制代码
None of the git remotes configured for this repository correspond to the GITLAB_HOST environment variable.

✅ 解决方案:

  1. 确认未设置 GITLAB_HOST

    bash 复制代码
    echo $GITLAB_HOST  # 应无输出
    unset GITLAB_HOST  # 临时清除
  2. 确认 remote URL 与配置匹配

    bash 复制代码
    git remote -v
    # 输出应为:http://GITLAB_IP_3/group/project.git
  3. 确认 hosts 键名是纯 IP(无端口)

💡 终极绕过命令(推荐):

bash 复制代码
GITLAB_HOST= git mrc source target

六、验证配置是否生效

bash 复制代码
# 查看当前项目关联的 GitLab 配置
glab config view

# 测试 API(以 GITLAB_IP_3 为例)
glab api --host GITLAB_IP_3 /user

如果返回用户信息,说明配置成功!


七、总结

步骤 关键点
安装 brew install glab
配置 config.ymlhosts 键名 = 纯 IP
Token 每个 GitLab 实例独立申请,权限 api + write_repository
别名 git mrc source target 一键创建 MR
避坑 不要设置 GITLAB_HOST不要带端口写 host 键名

通过上述配置,你可以在 同一个终端 中无缝切换多个 GitLab 项目,彻底告别网页点点点!


💡 推荐 :将 config.yml 加入你的 dotfiles 管理,方便在新机器快速部署。

🔒 再次强调:切勿将真实 Token 或 IP 提交到公开仓库!

如果你觉得这篇教程有用,欢迎点赞、收藏、转发!

有任何问题,欢迎在评论区交流 👇

相关推荐
大树881 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠1 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质1 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工1 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智1 天前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_1 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
施努卡机器视觉1 天前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
dayuOK63071 天前
写作卡壳怎么办?我的“5分钟启动法”
人工智能·职场和发展·自动化·新媒体运营·媒体
AC赳赳老秦1 天前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
java_cj1 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes