메인 콘텐츠로 건너뛰기

GitLab CI/CD 통합

Capgo Live Updates와 GitLab CI/CD를 통합하여 code 변경 사항을 푸시할 때마다 앱 업데이트를 자동으로 배포하세요. 이 가이드는 자동 빌드, 테스트 및 배포 워크플로우를 설정하는 방법을 다룹니다.

GitLab CI/CD 통합을 설정하기 전에 다음을 확인하세요:

  • GitLab 계정과 프로젝트 저장소
  • Capgo 계정과 앱이 구성된 Capgo
  • Node.js와 npm/yarn이 프로젝트에 구성된 경우

GitLab CI/CD 설정

설정하기: GitLab CI/CD

먼저, GitLab 프로젝트에서 필요한 변수를 설정하세요:

  1. GitLab 프로젝트로 이동하세요
  2. 로 가세요 설정CI/CD변수
  3. 다음 변수를 추가하세요:
변수 이름보호됨가려짐
CAPGO_TOKENCapgo API 토큰이 있습니다✅ 예✅ 예

기본 설정: 매인 branch로 푸시할 때마다 프로덕션으로 배포합니다.

# .gitlab-ci.yml - Simple Configuration
image: 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

기능 branch를 테스트 채널로 배포하여 검토 및 테스트합니다.

# Feature branch deployment
deploy_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_KEEP_0__의 암호화 기능을 사용 중이라면, Capgo’s encryption feature개인 키를 설정한 후에, GitLab 변수에 개인 키를 추가하세요:

터미널 창 복사 __CAPGO_KEEP_0__

__CAPGO_KEEP_0__
# Display your private key content (copy this output)
cat .capgo_key_v2

이 콘텐츠를 추가하세요 CAPGO_PRIVATE_KEY GitLab 프로젝트 변수에 추가하세요 (보호 및 가려짐으로 표시) 그리고 pipeline에서 사용하세요:

# Deploy with encryption
deploy_production:
script:
- npm install -g @capgo/cli
- npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --key-data-v2 "$CAPGO_PRIVATE_KEY" --channel production

__CAPGO_KEEP_0__에 대한 자세한 정보는 __CAPGO_KEEP_1__ 문서를 참조하십시오. __CAPGO_KEEP_1__ 문서.

다중 배포 채널을 관리하는 방법에 대한 자세한 정보는 __CAPGO_KEEP_0__ 문서를 참조하십시오.

# .gitlab-ci.yml - Advanced Multi-Channel Configuration
image: node:22
stages:
- build
- deploy
variables:
npm_config_cache: "$CI_PROJECT_DIR/.npm"
# Build stage
build:
stage: build
script:
- npm ci
- npm run test
- npm run build
artifacts:
paths:
- dist/
expire_in: 24 hours
# Deploy to development channel
deploy_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 channels
deploy_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 closed
cleanup_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 staging
deploy_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 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
environment:
name: production

수동 승인 필요 배포:

__CAPGO_COPY_TO_CLIPBOARD__

수동 승인 필요 배포:

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

__CAPGO_COPY_TO_CLIPBOARD__

Branch-Based 배포 전략

__CAPGO_SECTION_TITLE__ Branch-Based 배포 전략

# Dynamic channel deployment based on branch
deploy:
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

보안 최적화 방법

보안 최적화 방법 섹션
  1. 敏감 변수 표시: 항상 API 토큰을 보호하고 가려야 합니다.
  2. Branch 보호: 프로덕션 배포에 사용하는 경우 보호 변수를 사용하십시오.
  3. 접근 제어: 유지 보수자만 변수 접근을 제한하십시오.
  4. 정기적인 회전: API 토큰을 정기적으로 회전하십시오.
# Use protected variables for production
deploy_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"

pipeline에 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

pipeline이 ‘Capgo CLI not found’:로 실패합니다.

# Debug CLI installation
debug_cli:
script:
- npm install -g @capgo/cli
- which capgo || echo "Capgo CLI not found"
- npx @capgo/cli --version

인증 오류:

# Verify token configuration
debug_auth:
script:
- |
if [ -z "$CAPGO_TOKEN" ]; then
echo "CAPGO_TOKEN is not set"
exit 1
fi
echo "Token length: ${#CAPGO_TOKEN}"

빌드 아티팩트가 없습니다.

# List build outputs
debug_build:
script:
- ls -la dist/
- find dist/ -type f -name "*.js" -o -name "*.html"

Debug Pipeline

Debug Pipeline

문제를 해결하기 위해 디버깅 정보를 추가하세요.

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

다음 단계

Next Steps

Capgo CI/CD를 사용하여 모바일 앱 사용자에게 일관된 및 신뢰할 수 있는 업데이트를 보장하고 자동화된 배포를 수행할 수 있습니다.

GitLab CI/CD 통합에서 계속하기

GitLab CI/CD 통합에서 계속하기

GitLab CI/CD를 사용하는 경우 GitLab CI/CD 통합 GitLab CI/CD 통합을 사용하여 CI/CD 자동화 계획을 만든 경우에만 연결하십시오. Capgo CI/CD 제품 워크플로우에서 CI/CD에 대한 Capgo Capgo 네이티브 빌드 제품 워크플로우에서 Capgo 네이티브 빌드에 대한 Capgo 통합 제품 워크플로우에서 Capgo 통합에 대한 CI/CD 통합 CI/CD 통합에 대한 구현 세부 정보, 및 GitHub 액션 통합 구현 세부 정보에 대한 GitHub 액션 통합