GitLab CI/CD Integration
复制一个包含安装步骤和本插件的完整 Markdown 指南的配置提示。
将 Capgo Live Updates 与 GitLab CI/CD 集成,以便在推送 code 更改时自动部署您的应用程序更新。 本指南涵盖了设置自动构建、测试和部署工作流程。
前置条件
标题:前置条件在设置 GitLab CI/CD 集成之前,请确保您有:
- 一个 GitLab 帐户和一个项目仓库
- 一个 Capgo 帐户和一个已配置的应用
- Node.js 和 npm/yarn 在项目中配置
设置 GitLab CI/CD
标题:设置 GitLab CI/CD步骤 1:配置环境变量
标题:步骤 1:配置环境变量首先,在您的 GitLab 项目中设置必要的变量:
- 前往您的 GitLab 项目
- 前往 设置 → CI/CD → 变量
- 添加以下变量:
| 变量名称 | 值 | 保护 | 隐藏 |
|---|---|---|---|
CAPGO_TOKEN | 您的 Capgo API token | ✅ 是 | ✅ 是 |
简单
标题:简单基本配置,部署到生产环境每次推送到主分支:
# .gitlab-ci.yml - Simple Configurationimage: node:22
stages: - build - deploy
variables: npm_config_cache: "$CI_PROJECT_DIR/.npm"
build: stage: build script: - npm ci - npm run test - npm run build artifacts: paths: - dist/ expire_in: 1 hour only: - main
deploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production # For encrypted uploads, add: --key-data-v2 "$CAPGO_PRIVATE_KEY" dependencies: - build only: - main高级
高级功能分支部署
功能分支部署将功能分支部署到测试频道进行审查和测试:
# Feature branch deploymentdeploy_feature: stage: deploy script: - npm install -g @capgo/cli - CHANNEL_NAME="feature-$(echo $CI_COMMIT_REF_NAME | sed 's/[^a-zA-Z0-9-]/-/g')" - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME dependencies: - build only: - /^feature\/.*$/ environment: name: feature/$CI_COMMIT_REF_NAME url: https://your-app.com/channels/$CHANNEL_NAME使用加密
使用加密如果您正在使用 Capgo的加密功能,您需要在CI/CD环境中安全存储您的私钥。
之后 设置加密密钥 本地后,添加您的私钥到GitLab变量中:
# Display your private key content (copy this output)cat .capgo_key_v2将此内容添加为 CAPGO_PRIVATE_KEY 在您的GitLab项目变量中(标记为保护和掩码),然后在管道中使用它:
# Deploy with encryptiondeploy_production: script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --key-data-v2 "$CAPGO_PRIVATE_KEY" --channel production多渠道配置
多渠道配置有关设置和管理多个部署通道的详细信息,请参阅 Channels 文档.
多环境配置和合并请求部署:
# .gitlab-ci.yml - Advanced Multi-Channel Configurationimage: node:22
stages: - build - deploy
variables: npm_config_cache: "$CI_PROJECT_DIR/.npm"
# Build stagebuild: stage: build script: - npm ci - npm run test - npm run build artifacts: paths: - dist/ expire_in: 24 hours
# Deploy to development channeldeploy_development: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel development dependencies: - build only: - develop environment: name: development
# Deploy merge requests to test channelsdeploy_mr: stage: deploy script: - npm install -g @capgo/cli - CHANNEL_NAME="mr-$CI_MERGE_REQUEST_IID" - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME dependencies: - build only: - merge_requests environment: name: review/$CI_MERGE_REQUEST_IID url: https://your-app.com/channels/mr-$CI_MERGE_REQUEST_IID on_stop: cleanup_mr
# Cleanup MR channels when MR is closedcleanup_mr: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli channel delete mr-$CI_MERGE_REQUEST_IID --apikey $CAPGO_TOKEN || true when: manual environment: name: review/$CI_MERGE_REQUEST_IID action: stop only: - merge_requests
# Deploy to stagingdeploy_staging: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel staging dependencies: - build only: - develop environment: name: staging
# Deploy to productiondeploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production dependencies: - build only: - main environment: name: production需要手动审批的生产部署:
多环境部署(需要手动审批)生产部署需要手动审批时使用:
deploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production dependencies: - build only: - main when: manual environment: name: production基于分支的部署策略
基于分支的部署策略自动将不同分支部署到适当的频道:
# Dynamic channel deployment based on branchdeploy: stage: deploy script: - npm install -g @capgo/cli - | if [ "$CI_COMMIT_REF_NAME" = "main" ]; then CHANNEL="production" elif [ "$CI_COMMIT_REF_NAME" = "develop" ]; then CHANNEL="staging" else CHANNEL="development" fi - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL dependencies: - build environment: name: $CHANNEL安全最佳实践
安全最佳实践保护变量
保护变量- 保护敏感变量: 始终将 API 标记为保护和掩码
- Branch 保护: 使用保护变量进行生产部署
- 访问控制: 限制变量访问仅限维护人员
- 常规轮换: 定期轮换 API 变量
安全管道配置
安全管道配置# Use protected variables for productiondeploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production only: refs: - main variables: - $CI_COMMIT_REF_PROTECTED == "true"监控和通知
监控和通知部分Slack 集成
Slack 集成部分将 Slack 通知添加到管道中:
notify_success: stage: .post image: alpine:latest before_script: - apk add --no-cache curl script: - | curl -X POST -H 'Content-type: application/json' \ --data '{"text":"✅ Capgo deployment successful for '"$CI_COMMIT_REF_NAME"'"}' \ $SLACK_WEBHOOK_URL when: on_success
notify_failure: stage: .post image: alpine:latest before_script: - apk add --no-cache curl script: - | curl -X POST -H 'Content-type: application/json' \ --data '{"text":"❌ Capgo deployment failed for '"$CI_COMMIT_REF_NAME"'"}' \ $SLACK_WEBHOOK_URL when: on_failure电子邮件通知
监控和通知部分配置 GitLab 项目设置中的电子邮件通知或使用 API:
notify_email: stage: .post script: - | curl --request POST \ --header "PRIVATE-TOKEN: $GITLAB_API_TOKEN" \ --form "to=team@yourcompany.com" \ --form "subject=Capgo Deployment Status" \ --form "body=Deployment of $CI_COMMIT_REF_NAME completed with status: $CI_JOB_STATUS" \ "https://gitlab.com/api/v4/projects/$CI_PROJECT_ID/emails" when: always故障排除
故障排除部分常见问题
常见问题标题管道失败:"Capgo CLI 未找到"
# Debug CLI installationdebug_cli: script: - npm install -g @capgo/cli - which capgo || echo "Capgo CLI not found" - npx @capgo/cli --version认证错误:
# Verify token configurationdebug_auth: script: - | if [ -z "$CAPGO_TOKEN" ]; then echo "CAPGO_TOKEN is not set" exit 1 fi echo "Token length: ${#CAPGO_TOKEN}"无法找到构建产物:
# List build outputsdebug_build: script: - ls -la dist/ - find dist/ -type f -name "*.js" -o -name "*.html"调试管道
调试管道标题添加调试信息以解决问题:
debug: stage: build script: - echo "Branch: $CI_COMMIT_REF_NAME" - echo "Commit: $CI_COMMIT_SHA" - echo "Build: $CI_PIPELINE_ID" - env | grep CI_ | sort only: - branches下一步
下一步部分通过 GitLab CI/CD 集成,您可以自动化您的 Capgo 部署并确保您的移动应用程序用户接收到一致可靠的更新。
继续从 GitLab CI/CD 集成
标题:继续从 GitLab CI/CD 集成如果您正在使用 GitLab CI/CD 集成 规划 CI/CD 自动化 Capgo CI/CD Capgo CI/CD 在 Capgo CI/CD 中的产品工作流程 Capgo 原生构建 Capgo 集成 为产品工作流程在 Capgo 集成中 CI/CD 集成 为 CI/CD 集成的实现细节 GitHub 动作集成 为 GitHub 动作集成的实现细节