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:
- Prepara il tuo ambiente: Installa gli strumenti richiesti per iOS e Android.
- Configura il tuo progetto: Aggiorna
capacitor.config.tse gestisci le variabili di ambiente in modo sicuro. - Pipeline di costruzione: Automatizza l'installazione delle dipendenze, la costruzione e i test per entrambe le piattaforme.
- Optimizza le prestazioni: Utilizza il caching, la costruzione in parallelo e le workflow condizionali.
- 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

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 codeANDROID_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:
| Piattaforma | Tipo di artefatto | Canale di distribuzione |
|---|---|---|
| iOS | .ipa | App Store Connect |
| Android | .aab | Google 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

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
| Caratteristica | Descrizione |
|---|---|
| Crittografia End-to-End | Riduce significativamente gli errori di distribuzione. |
| Distribuzione per Canali | Adatta gli aggiornamenti a specifiche ambientazioni. |
| Esecuzione di Aggiornamenti in Fasi | Assicura 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.
| Ambiente | File di configurazione |
|---|---|
| Sviluppo | .env.dev |
| Stagging | .env.staging |
| Produzione | Cassaforte 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:
-
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 -
Aggiungi il supporto per le piattaforme: Aggiungi le piattaforme che desideri raggiungere, come iOS o Android:
npx cap add ios npx cap add android -
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.