GitLab Runner: 4. 建立服務

此文件屬於使用 CLI 自動化操作指南的一部分。請在此處查看完整指南:透過 Stackhero CLI 程式化啟動 GitLab-Runner、取得其認證資料,以及變更其設定

👋 歡迎瀏覽 Stackhero 文件!

Stackhero 為您提供易於使用的 GitLab Runner cloud 解決方案,專為高效處理您的 GitLab CI/CD 任務而設計。您可以享有以下優勢:

  • 無限 CI/CD 時數:不按分鐘收費,您的 pipeline 可隨時運行。
  • 多個並行任務:同時運行多個 job,加快整個 pipeline 的速度。
  • 支援 Docker executorDocker-in-Docker:簡化容器映像的建構及推送流程。
  • 相容於 GitLab.com 及任何 自建 GitLab 實例。
  • 專屬私人 VM,採用高速 NVMe/SSD 硬碟,確保 build 穩定可靠。
  • 提供 🇪🇺 歐洲🇺🇸 美國 區域選擇。

節省時間:您只需幾分鐘即可連接第一個 GitLab Runner,立即開始運行 pipeline!

以下是一個範例腳本,會建立一個 stack,將您的 GitLab-Runner 服務加入其中,等待服務啟動,取得其設定(包括自動產生的認證資料),然後套用新的設定。

#!/bin/bash
set -e

export STACKHERO_TOKEN="usr-xxxxxx:your-token"

serviceStore="gitlab-runner"   # GitLab-Runner 服務 store 名稱(見步驟 2)
instance="..."                # 步驟 3 選擇的實例規格
region="europe"               # 步驟 3 選擇的地區名稱

# 建立服務專用的 stack(預設使用您的主要組織;如有需要可加 --organization)
stackId=$(stackhero --format=script stack-create \
  --name="My GitLab-Runner stack")
echo "Stack created: ${stackId}"

# 將 GitLab-Runner 加入 stack(名稱會自動解析)
serviceId=$(stackhero --format=script service-add \
  --stack="My GitLab-Runner stack" \
  --service-store="${serviceStore}" \
  --instance="${instance}" \
  --region="${region}")
echo "Service added: gitlab-runner"

# 等待服務完全啟動(可能需數分鐘)
stackhero service-wait-for --service="gitlab-runner"

# 取得服務設定,包括自動產生的認證資料
stackhero service-configuration-get --service="gitlab-runner" --format=json