Vai direttamente al contenuto principale

Configurazione della CI/CD per le app Capacitor

Scopri come semplificare le tue rilasci di app per iOS e Android utilizzando le pipeline CI/CD, aumentando l'efficienza e riducendo gli errori.

Martin Donadieu

Martin Donadieu

Content Marketer

Configurazione della CI/CD per le app Capacitor

Vuoi rilasciare le tue app per iOS e Android più velocemente e senza errori? Pipeline CI/CD per Capacitor gli app automatizzano la costruzione, il testing e la distribuzione, riducendo i tempi di rilascio di fino al 70% e gli errori del 60%. Questa guida copre tutto ciò di cui hai bisogno, dalla configurazione del tuo ambiente all'automazione degli aggiornamenti in tempo reale con Capgo.

Punti chiave:

  • Perché la CI/CD è importante per Capacitorapp
  • : Rende i build più veloci del 78% e riduce le rifiute di negozio del 60%.: Strumenti essenziali, Xcode, Android StudioCocoaPods
  • Impostazione della pipeline: Automatizza compiti come npx cap sync, caching delle dipendenze e costruzioni specifiche per piattaforma.
  • Aggiornamenti in tempo reale con Capgo: Abilita gli aggiornamenti post-rilascio con roll-out fasi e salvaguardie di rollback.

Passaggi di configurazione rapida:

  1. Prepara il tuo ambiente: Installa gli strumenti richiesti per iOS e Android.
  2. Configura il tuo progetto: Aggiorna capacitor.config.ts e gestisci le variabili di ambiente in modo sicuro.
  3. Pipeline di costruzione: Automatizza l'installazione delle dipendenze, la costruzione e i test per entrambe le piattaforme.
  4. Optimizza le prestazioni: Utilizza il caching, la costruzione in parallelo e le workflow condizionali.
  5. Aggiungi aggiornamenti in tempo reale: Integra Capgo per aggiornamenti OTA sicuri con roll-out fasi.

Con CI/CD, le app Capacitor raggiungono rilasci più veloci e lisci, riducendo gli errori e l'intervento manuale. Pronto a ottimizzare il tuo workflow? Entriamo nel vivo!

Integra le tue pipeline CI/CD esistenti con capacità mobili

Preparazione dell'ambiente CI/CD

Una volta che hai affrontato le basi di CI/CD, il passo successivo è la configurazione dell'ambiente. Questo è il nucleo dell'automazione affidabile.

Strumenti e configurazione del software

Assicurati di avere questi strumenti chiave installati:

Per lo Sviluppo di iOS:

  • Xcode 14 o versione successiva
  • Xcode Command Line Tools
  • CocoaPods per la gestione delle dipendenze

Per lo Sviluppo di Android:

  • Android Studio
  • Android SDK 33 o superiore
  • Java Development Kit (JDK)

Per confermare che i tuoi Xcode Command Line Tools sono installati, utilizza:

xcode-select -p

Creazione di un Capacitor Progetto

Capacitor Framework Documentazione Sito Web

Il tuo progetto Capacitor deve essere configurato correttamente per i flussi di lavoro CI/CD. Il capacitor.config.ts Il file è al cuore di questa configurazione:

const config: CapacitorConfig = {
  appId: 'com.example.app',
  webDir: 'build',
  ios: { 
    scheme: 'MyApp'
  }
}

Questo file assicura che il tuo progetto si allinei con le richieste dei flussi di lavoro CI/CD.

Configurazione delle Variabili di Ambiente

Gestire le credenziali in modo sicuro è una parte chiave del collegamento della configurazione dell'ambiente con il flusso di lavoro CI/CD.

Variabili Chiave da Definire:

  • BUILD_ENV: Specifica la fase di distribuzione (ad esempio, production)
  • IOS_SIGNING_IDENTITY: Il tuo certificato di firma code
  • ANDROID_KEYSTORE_PATH: Percorso del tuo keystore Android

Per le build Android, generare dinamicamente un local.properties file durante il processo di CI:

echo "sdk.dir=$ANDROID_SDK_ROOT" > android/local.properties

Lavorando con build iOS, assicurati che il tuo piattaforma di CI supporti gli agenti macOS.

Per verificare se il tuo ambiente è pronto:

node --version | grep "v16" && xcodebuild -version | grep "Xcode 14" || exit 1

Gestire correttamente le chiavi e i credenziali può significativamente ridurre le possibilità di rifiuti dell'app store, come riportato nelle statistiche precedenti [1].

Creare la tua pipeline CI/CD

Una volta pronto il tuo ambiente, il passo successivo è la configurazione di una pipeline CI/CD per il tuo Capacitorapp. Questa pipeline dovrebbe gestire in modo efficiente sia gli asset web che le build delle piattaforme native.

Installazione e Aggiornamento delle Dipendenze

Nelle ambientazioni CI/CD, la gestione delle dipendenze richiede un controllo di versione rigoroso. Inizia con un processo di installazione pulita:

npm install --ignore-scripts
npm install @capacitor/cli

Per accelerare i build, utilizza il caching delle dipendenze. Ad esempio, Azure DevOps gli utenti hanno visto migliorare i tempi di costruzione del 40-60% con questo setup:

- task: Cache@2
  inputs:
    key: 'npm | "$(Agent.OS)" | package-lock.json'
    path: |
      node_modules
      android/.gradle
      ios/Pods

Configurazione di costruzione per iOS e Android

Ecco come configurare le costruzioni per entrambe le piattaforme:

Configurazione di costruzione per iOS:

steps:
  - task: InstallAppleCertificate@2
    inputs:
      certSecureFile: 'certificate.p12'
      certPwd: $(P12_PASSWORD)
  - script: |
      xcodebuild -workspace ios/App/App.xcworkspace -scheme App -configuration Release -archivePath ios/App/App.xcarchive archive

Configurazione di costruzione per Android:

cd android
./gradlew bundleRelease

Passaggi di testing e distribuzione

Eseguire test di piattaforma in parallelo utilizzando una strategia di matrice:

test:
  steps:
    - run: npm run test:unit
    - run: npm run test:e2e
    - name: Run Platform Tests
      matrix:
        platform: [ios, android]
      run: npm run test:${{ matrix.platform }}

Per la distribuzione, configurare il trattamento di artefatti specifici per piattaforma:

PiattaformaTipo di artefattoCanale di distribuzione
iOS.ipaApp Store Connect
Android.aabGoogle Play Console

Utilizzando i costruzioni parallele si può ridurre significativamente il tempo di esecuzione della pipeline quando configurato correttamente.

Una volta che i tuoi build sono stati validati e pacchettizzati, sei pronto a passare alle aggiornamenti in tempo reale con Capgo (discusso nella sezione successiva).

sbb-itb-f9944d2

Aggiungere Capgo per Aggiornamenti in Tempo Reale

Capgo Dashboard di Aggiornamento in Tempo Reale

Integrando Capgo nel tuo workflow migliora il tuo processo CI/CD consentendo aggiornamenti post-rilascio. Ecco come configurarlo:

Configurazione della pipeline Capgo

In primo luogo, installa il Capgo CLI nel tuo ambiente di pipeline:

steps:
  - name: Install Capgo CLI
    run: npm install -g @capgo/cli
  - name: Configure Authentication
    env:
      CAPGO_KEY: ${{ secrets.CAPGO_API_KEY }}

Questa aggiunta estende il tuo ciclo di vita CI/CD incorporando la gestione degli aggiornamenti nel tuo processo di costruzione e distribuzione automatizzata. Successivamente, includi il comando di caricamento dopo i passaggi di costruzione:

Per

- name: Upload Update
  run: |
    capgo upload --api-key $CAPGO_KEY --bundle ./build/app-release.apk
    capgo deploy v${VERSION} --channel production

aggiornamenti sicuri , configura le impostazioni di validazione come segue:__CAPGO_KEEP_2__

{
  "verification": {
    "checksum": "strict",
    "certificatePinning": true,
    "updateTimeout": 500
  }
}

Capgo Caratteristiche Panoramica

CaratteristicaDescrizione
Crittografia End-to-EndRiduce significativamente gli errori di distribuzione.
Distribuzione per CanaliAdatta gli aggiornamenti a specifiche ambientazioni.
Esecuzione di Aggiornamenti in FasiAssicura che gli aggiornamenti siano distribuiti gradualmente.

Linee Guida per Aggiornamenti OTA

Rafforza i processi di testing tracciando questi metriche chiave dopo la distribuzione:

Strategia di Esecuzione di Aggiornamenti in Fasi

Utilizza un rilascio in fase di staging per controllare come vengono distribuite le aggiornamenti:

- name: Staged Rollout
  run: |
    capgo deploy v1.2.3 --group "beta-users" --rollout 10%
    capgo deploy v1.2.3 --rollout 50%

Monitoraggio degli Aggiornamenti

Tieni d'occhio questi metriche:

  • Tasso di adozione: Mirare a 40-60% entro le prime 24 ore.
  • Sessioni senza crash: Mantenere sopra il 99,5%.
  • Tempo di verifica: Assicurati che sia inferiore a 500ms.

Se i crash superano i livelli accettabili, automatizza un rollback:

- name: Rollback Check
  run: |
    if [ $(capgo stats --version v1.2.3 --metric crashes) -gt 2 ]; then
      capgo rollback --channel production
    fi

Miglioramento della Prestazione della Pipeline

Sfocando su tre aree chiave può portare a miglioramenti notevoli nella tua pipeline:

Optimizzazione della Velocità di Costruzione

Per le modifiche esclusivamente web, utilizzando npx cap sync può risparmiare tempo evitando ricostruzioni native complete, riducendo il tempo di ricostruzione di circa il 40%. Ecco come puoi implementare la costruzione condizionale:

- name: Build Strategy
  run: |
    [ "$WEB_ONLY" = true ] && npx cap sync || (./gradlew assembleRelease && xcodebuild ...)

Questa approccio garantisce che solo i componenti necessari vengono ricostruiti, semplificando il processo.

Automazione del Controllo di Versione

L'automazione del controllo di versione può semplificare il tuo workflow. Utilizza lo script seguente per impostare dinamicamente numeri di versione e di costruzione:

- name: Set Version
  run: |
    VERSION=$(node -p "require('./package.json').version")
    BUILD_NUMBER=$GITHUB_RUN_NUMBER
    echo "APP_VERSION=${VERSION}" >> $GITHUB_ENV
    echo "BUILD_ID=${BUILD_NUMBER}" >> $GITHUB_ENV

Inoltre, la versione semantica automatizzata può essere configurata con questa impostazione:

{
  "scripts": {
    "version": "standard-version",
    "build:prod": "npm version patch && ionic build --prod"
  }
}

Queste pratiche forniscono un solido framework per il tracciamento e l'ottimizzazione delle prestazioni della pipeline attraverso metriche come:

  • Tempo di costruzione per fase
  • Efficienza della cache (rapporti di colpo/errore)
  • Utilizzo massimo di risorse

Impostazione di più Ambienti

La gestione di più ambienti può essere semplificata utilizzando configurazioni specifiche per l'ambiente.

AmbienteFile di configurazione
Sviluppo.env.dev
Stagging.env.staging
ProduzioneCassaforte sicuro

Puoi configurare gli ambienti dinamicamente con questo script:

- name: Configure Environment
  env:
    API_KEY: ${{ secrets.ENV_SPECIFIC_API_KEY }}
    BUNDLE_ID: ${{ parameters.bundleId }}
  run: |
    echo "ENVIRONMENT=${{ parameters.environment }}" >> $GITHUB_ENV
    echo "API_ENDPOINT=${{ parameters.apiUrl }}" >> $GITHUB_ENV

L'associazione di queste configurazioni con il canale di distribuzione di Capgo consente aggiornamenti precisi e specifici per l'ambiente. Ciò garantisce rilasci più fluidi e un controllo migliore sul comportamento dell'applicazione in diversi ambienti.

Riepilogo

Il ruolo di CI/CD nello sviluppo

L'utilizzo di pipeline CI/CD per le app Capacitor aumenta significativamente l'efficienza del workflow. Secondo i dati dell'industria, i team possono raggiungere 50-70% cicli di rilascio più veloci grazie a costruzioni iOS e Android simultanee grazie a costruzioni iOS e Android simultanee [3]. L'automazione di compiti come l'installazione delle dipendenze e la sincronizzazione delle piattaforme riduce gli errori di distribuzione di 40-60% [1][2].

Esempi di team che utilizzano pipeline di Azure DevOps hanno automatizzato processi come passaggi di costruzione sequenziali e packaging Xcode. Utilizzano anche ambienti parametrizzati per lo sviluppo e la produzione. Questa approccio elimina la necessità di operazioni manuali di Gradle e Xcode CLI, garantendo la creazione di artefatti affidabili ogni volta.

Queste migliorie creano le basi per una gestione degli aggiornamenti più fluida quando utilizzata con Capgo.

Capgo per la Gestione degli Aggiornamenti

Capgo funziona in modo trasparente con pipeline CI/CD per fornire aggiornamenti istantanei mentre rimane conforme alle politiche delle store di app. Gli aggiornamenti vengono distribuiti solo dopo aver superato i test automatizzati integrati nella pipeline.

Combiniando costruzioni automatizzate con rilasci fasi, le squadre ottengono risultati impressionanti: 80% di copertura degli utenti entro 7 giorni e capacità di rollback in meno di un'ora.

Una strategia comune consiste nel gestire tracce di distribuzione parallele. Le costruzioni automatizzate vengono utilizzate per i test interni, mentre i rilasci fasi si concentrano su segmenti di utenti. Ciò garantisce che gli aggiornamenti siano sia veloci che sicuri, supportati da rigorosi porte di test automatizzate [1].

Domande frequenti

How to create a Capacitor app?

Creare un'app Capacitor richiede pochi passaggi semplici:

  1. Configura il tuo ambiente: Installa Node.js e npm sul tuo sistema. Poi, utilizza l'CLI di Ionic per avviare un nuovo progetto con supporto per Capacitor:

    ionic start myApp tabs --capacitor
  2. Aggiungi il supporto per le piattaforme: Aggiungi le piattaforme che desideri raggiungere, come iOS o Android:

    npx cap add ios
    npx cap add android
  3. Sincronizza il tuo web code: Assicurati che il tuo web code sia allineato con le piattaforme native eseguendo:

    npx cap sync

Il passaggio di sincronizzazione è cruciale per mantenere l'app coerente across le piattaforme e garantire un funzionamento liscio nelle pipeline CI/CD. Per ulteriori informazioni sulla configurazione del tuo ambiente, consulta la sezione Strumenti.

Aggiornamenti in tempo reale per le app Capacitor

Quando un bug nel layer web è attivo, invia la correzione attraverso Capgo invece di aspettare giorni per l'approvazione della store. Gli utenti ricevono l'aggiornamento in background mentre le modifiche native rimangono nel normale percorso di revisione.

Inizia subito

Ultimi articoli dal nostro Blog

Capgo ti offre le migliori informazioni che ti servono per creare un'app mobile veramente professionale.