GitLab CI/CD 통합
Capgo Live Updates를 GitLab CI/CD와 통합하여 코드 변경 사항을 푸시할 때마다 앱 업데이트를 자동으로 배포하세요. 이 가이드는 자동화된 빌드, 테스트 및 배포 워크플로우 설정을 다룹니다.
사전 요구 사항
Section titled “사전 요구 사항”GitLab CI/CD 통합을 설정하기 전에 다음을 준비해야 합니다:
- 프로젝트 저장소가 있는 GitLab 계정
- 구성된 앱이 있는 Capgo 계정
- 프로젝트에 구성된 Node.js 및 npm/yarn
GitLab CI/CD 설정
Section titled “GitLab CI/CD 설정”1단계: 환경 변수 구성
Section titled “1단계: 환경 변수 구성”먼저 GitLab 프로젝트에 필요한 변수를 설정합니다:
- GitLab 프로젝트로 이동
- Settings → CI/CD → Variables로 이동
- 다음 변수 추가:
| 변수 이름 | 값 | Protected | Masked |
|---|---|---|---|
CAPGO_TOKEN | Capgo API 토큰 | ✅ 예 | ✅ 예 |
간단한 구성
Section titled “간단한 구성”main 브랜치에 푸시할 때마다 프로덕션에 배포하는 기본 구성:
# .gitlab-ci.yml - 간단한 구성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 # 암호화된 업로드의 경우 추가: --key-data-v2 "$CAPGO_PRIVATE_KEY" dependencies: - build only: - main기능 브랜치 배포
Section titled “기능 브랜치 배포”검토 및 테스트를 위해 기능 브랜치를 테스트 채널에 배포:
# 기능 브랜치 배포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암호화 사용
Section titled “암호화 사용”Capgo의 암호화 기능을 사용하는 경우 CI/CD 환경에 개인 키를 안전하게 저장해야 합니다.
로컬에서 암호화 키 설정 후 GitLab 변수에 개인 키를 추가하세요:
# 개인 키 콘텐츠 표시(이 출력 복사)cat .capgo_key_v2이 콘텐츠를 GitLab 프로젝트 변수에 CAPGO_PRIVATE_KEY로 추가(protected 및 masked로 표시)한 다음 파이프라인에서 사용:
# 암호화로 배포deploy_production: script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --key-data-v2 "$CAPGO_PRIVATE_KEY" --channel production다중 채널 구성
Section titled “다중 채널 구성”여러 배포 채널 설정 및 관리에 대한 포괄적인 정보는 Channels 문서를 참조하세요.
여러 환경 및 병합 요청 배포가 포함된 완전한 구성:
# .gitlab-ci.yml - 고급 다중 채널 구성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: 24 hours
# 개발 채널에 배포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_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
# MR이 닫힐 때 MR 채널 정리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_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_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수동 승인이 있는 다중 환경
Section titled “수동 승인이 있는 다중 환경”수동 승인이 필요한 프로덕션 배포의 경우:
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브랜치 기반 배포 전략
Section titled “브랜치 기반 배포 전략”다른 브랜치를 적절한 채널에 자동으로 배포:
# 브랜치에 따른 동적 채널 배포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보안 모범 사례
Section titled “보안 모범 사례”보호된 변수
Section titled “보호된 변수”- 민감한 변수 표시: API 토큰을 항상 protected 및 masked로 표시
- 브랜치 보호: 프로덕션 배포에 보호된 변수 사용
- 액세스 제어: 변수 액세스를 maintainer에게만 제한
- 정기 교체: API 토큰을 정기적으로 교체
안전한 파이프라인 구성
Section titled “안전한 파이프라인 구성”# 프로덕션에 보호된 변수 사용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"모니터링 및 알림
Section titled “모니터링 및 알림”Slack 통합
Section titled “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이메일 알림
Section titled “이메일 알림”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일반적인 문제
Section titled “일반적인 문제”“Capgo CLI not found”로 파이프라인 실패:
# CLI 설치 디버그debug_cli: script: - npm install -g @capgo/cli - which capgo || echo "Capgo CLI not found" - npx @capgo/cli --version인증 오류:
# 토큰 구성 확인debug_auth: script: - | if [ -z "$CAPGO_TOKEN" ]; then echo "CAPGO_TOKEN is not set" exit 1 fi echo "Token length: ${#CAPGO_TOKEN}"빌드 아티팩트를 찾을 수 없음:
# 빌드 출력 나열debug_build: script: - ls -la dist/ - find dist/ -type f -name "*.js" -o -name "*.html"파이프라인 디버그
Section titled “파이프라인 디버그”문제를 해결하기 위한 디버깅 정보 추가:
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- 다양한 배포 환경을 관리하려면 Channels에 대해 알아보기
- 고급 배포 시나리오를 위해 Custom Storage 살펴보기
- 안전한 배포를 위해 Encryption 설정
- 업데이트 적용 방법을 사용자 정의하기 위해 Update Behavior 구성
GitLab CI/CD 통합을 통해 Capgo 배포를 자동화하고 모바일 앱 사용자에게 일관되고 안정적인 업데이트를 보장할 수 있습니다.