使用 `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 提交到公开仓库!

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

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

相关推荐
zandy101111 小时前
衡石科技Agentic BI实战:基于自然语言查询与自动化分析的新一代智能系统
运维·科技·自动化·agentic bi
AiTEN_Robot11 小时前
机器人叉车的技术落地与效率挖掘:仓储自动化的效能提升方案
运维·机器人·自动化
卓应米老师11 小时前
【网络配置实战】堆叠的配置
运维·服务器·网络·华为认证
乐维_lwops11 小时前
告别机房管理 “盲盒”!实现主动预判的可视化运维
运维
2301_7679026411 小时前
第 4 章 docker容器
运维·docker·容器
历程里程碑11 小时前
Linux 2 指令(2)进阶:内置与外置命令解析
linux·运维·服务器·c语言·开发语言·数据结构·ubuntu
天荒地老笑话么11 小时前
Linux 里 chmod 755 file.txt 是什么意思(权限配置)
linux·运维·服务器·网络安全
野生工程师12 小时前
【Linux基础-2】Linux的基本指令
linux·运维·windows
Amarone12 小时前
Uptime Kuma 部署安装运维手册
运维·uptime kuma
昨夜见军贴061612 小时前
IACheck AI审核推动质量控制记录标准化,全面保障含量测定研究合规性
大数据·运维·人工智能