Debug AEM build e implementazioni as a Cloud Service

Adobe Cloud Manager facilita la creazione e l’implementazione del codice AEM as a Cloud Service. Possono verificarsi errori durante i passaggi del processo di compilazione, che richiedono un’azione per risolverli. Questa guida illustra gli errori comuni nell’implementazione e le modalità per affrontarli al meglio.

Pipe di generazione gestisci cloud

Convalida

Il passaggio di convalida assicura semplicemente la validità delle configurazioni di base di Cloud Manager. Gli errori di convalida comuni includono:

Lo stato dell'ambiente non è valido

  • Messaggio di errore: Lo stato dell'ambiente non è valido.
    Lo stato dell'ambiente non è valido
  • Causa: L’ambiente di destinazione della pipeline si trova in uno stato di transizione in cui non può accettare nuove build.
  • Risoluzione: Attendere che lo stato venga risolto in uno stato di esecuzione (o aggiornamento disponibile). Se l’ambiente viene eliminato, ricrea l’ambiente o scegli un ambiente diverso in cui generare la build.

Impossibile trovare l’ambiente associato alla pipeline

  • Messaggio di errore: L’ambiente viene contrassegnato come eliminato.
    L’ambiente viene contrassegnato come eliminato
  • Causa: L’ambiente configurato per l’utilizzo della pipeline è stato eliminato.
    Anche se viene ricreato un nuovo ambiente con lo stesso nome, Cloud Manager non riassocia automaticamente la pipeline a tale ambiente con lo stesso nome.
  • Risoluzione: Modifica la configurazione della pipeline e seleziona nuovamente l’ambiente in cui distribuire.

Impossibile trovare il ramo Git associato alla pipeline

  • Messaggio di errore: pipeline non valida: XXXXXX Reason=Branch=xxxx non trovato nell'archivio.
    pipeline non valida: XXXXXX Reason=Branch=xxxx non trovato nell'archivio
  • Causa: Il ramo Git che la pipeline è configurata per l’utilizzo è stato eliminato.
  • Risoluzione: Ricrea il ramo Git mancante con lo stesso nome oppure riconfigura la pipeline in modo da creare da un ramo diverso esistente.

Build & Unit Testing

Test di build e unità

La fase Build e Unit Testing esegue una build Maven (mvn clean package) del progetto estratto dal ramo Git configurato della pipeline.

Gli errori individuati in questa fase devono essere riproducibili nella creazione locale del progetto, con le seguenti eccezioni:

  • Una dipendenza Maven non disponibile su Maven Central viene utilizzato e l’archivio Maven contenente la dipendenza è:
    • Non raggiungibile da Cloud Manager, ad esempio un archivio Maven interno privato, oppure l’archivio Maven richiede l’autenticazione e sono state fornite le credenziali errate.
    • Non esplicitamente registrato nel pom.xml. Tieni presente che, l’inclusione degli archivi Maven è scoraggiata in quanto aumenta i tempi di creazione.
  • I test di unità non riescono a causa di problemi di temporizzazione. Ciò può verificarsi quando le prove di unità sono sensibili alla tempistica. Un indicatore forte si basa su .sleep(..) nel codice di prova.
  • L’utilizzo di plug-in Maven non supportati.

Scansione del codice

Scansione del codice

La scansione del codice esegue l’analisi del codice statico utilizzando una combinazione di procedure consigliate specifiche per Java e AEM.

La scansione del codice causa un errore di compilazione se nel codice sono presenti vulnerabilità di sicurezza critica. Le violazioni minori possono essere ignorate, ma si consiglia di correggerle. La scansione del codice è imperfetta e può causare falsi positivi.

Per risolvere i problemi di scansione del codice, scarica il rapporto in formato CSV fornito da Cloud Manager tramite il Dettagli di download e controlla tutte le voci.

Per ulteriori dettagli, consulta AEM regole specifiche, consulta la documentazione di Cloud Manager regole di scansione del codice specifiche AEM personalizzate.

Creare immagini

Creare immagini

L’immagine Build è responsabile della combinazione degli artefatti di codice generati nel passaggio Build & Unit Testing (Generazione e test di unità) con la versione AEM, per creare un singolo artefatto distribuibile.

Mentre durante il test Build & Unit vengono rilevati eventuali problemi di compilazione e compilazione del codice, possono verificarsi problemi di configurazione o di struttura durante il tentativo di combinare l'artefatto di build personalizzato con la versione AEM.

Configurazioni OSGi duplicate

Quando più configurazioni OSGi vengono risolte tramite la modalità runmode per l'ambiente di AEM di destinazione, il passaggio Genera immagine non riesce e viene restituito l'errore:

[ERROR] Unable to convert content-package [/tmp/packages/enduser.all-1.0-SNAPSHOT.zip]:
Configuration ‘com.example.ExampleComponent’ already defined in Feature Model ‘com.example.groupId:example.all:slingosgifeature:xxxxx:X.X’,
set the ‘mergeConfigurations’ flag to ‘true’ if you want to merge multiple configurations with same PID

Causa 1

  • Causa: Il pacchetto all del progetto AEM contiene più pacchetti di codice e la stessa configurazione OSGi viene fornita da più pacchetti di codice, dando luogo a un conflitto, impedendo al passaggio Build Image di decidere quale deve essere utilizzato, non riuscendo quindi nella compilazione. Questo non si applica alle configurazioni di fabbrica OSGi, purché abbiano nomi univoci.
  • Risoluzione: Rivedi tutti i pacchetti di codice (compresi eventuali pacchetti di codice di terze parti inclusi) che vengono distribuiti come parte dell’applicazione AEM, alla ricerca di configurazioni OSGi duplicate che risolvono, tramite modalità runmode, l’ambiente di destinazione. La guida del messaggio di errore "imposta il flag mergeConfigurations su true" non è possibile in AEM as a Cloud Service e deve essere ignorata.

Causa 2

  • Causa: Il progetto AEM include erroneamente lo stesso pacchetto di codice due volte, con conseguente duplicazione di qualsiasi configurazione OSGi contenuta in tale pacchetto.
  • Risoluzione: Rivedi tutti i pacchetti pom.xml incorporati nel progetto all e assicurati che abbiano il filevault-package-maven-plugin configurazione impostato su <cloudManagerTarget>none</cloudManagerTarget>.

Script di reindirizzamento non valido

Gli script di reindirizzamento definiscono il contenuto di base, gli utenti, le ACL, ecc. In AEM as a Cloud Service, gli script di reindirizzamento vengono applicati durante la creazione dell’immagine, tuttavia AEM’avvio rapido locale dell’SDK vengono applicati quando viene attivata la configurazione di fabbrica del repoinit OSGi. Per questo motivo, gli script di Repoinit potrebbero avere esito negativo (con la registrazione) sull’avvio rapido locale AEM’SDK e causare un errore nel passaggio Genera immagine, arrestando la distribuzione.

  • Causa: Uno script repoinit non è valido. Questo potrebbe lasciare il tuo archivio in uno stato incompleto come qualsiasi script di reindirizzamento dopo che lo script non riuscito verrà eseguito contro il repository.
  • Risoluzione: Rivedi l’avvio rapido locale dell’SDK AEM quando la configurazione OSGi dello script di reindirizzamento viene distribuita per determinare se e quali sono gli errori.

Dipendenza contenuto reindirizzamento non soddisfatta

Gli script di reindirizzamento definiscono il contenuto di base, gli utenti, le ACL, ecc. In AEM’avvio rapido locale dell’SDK, gli script di reindirizzamento vengono applicati quando viene attivata la configurazione di fabbrica OSGi di reindirizzamento, o in altre parole, dopo che l’archivio è attivo e possono aver subito modifiche di contenuto direttamente o tramite pacchetti di contenuto. In AEM as a Cloud Service, gli script di reindirizzamento vengono applicati durante la funzione Genera immagine rispetto a un archivio che potrebbe non contenere il contenuto da cui dipende lo script di repoinit.

  • Causa: Uno script di reindirizzamento dipende dal contenuto inesistente.
  • Risoluzione: Assicurati che il contenuto da cui dipende lo script di reindirizzamento esista. Spesso, questo indica uno script di reindirizzamento non adeguatamente definito che non contiene direttive che definiscono queste strutture di contenuto mancanti, ma necessarie. Questo può essere riprodotto localmente eliminando AEM, disimpacchettando il Jar e aggiungendo alla cartella di installazione la configurazione OSGi di reindirizzamento contenente lo script di reindirizzamento e avviando AEM. L'errore si presenterà nel file error.log locale dell'SDK AEM.

La versione dei componenti core dell'applicazione è maggiore della versione distribuita

Questo problema riguarda solo gli ambienti non di produzione che NON eseguono l'aggiornamento automatico alla versione più recente di AEM.

AEM as a Cloud Service include automaticamente la versione più recente dei componenti core in ogni versione di AEM, ovvero dopo che un ambiente as a Cloud Service AEM viene aggiornato automaticamente o manualmente, viene distribuita la versione più recente dei componenti core.

È possibile che il passaggio Genera immagine non riesca quando:

  • L’applicazione di distribuzione aggiorna la versione della dipendenza Maven dei componenti core nel core Progetto (bundle OSGi)
  • L’applicazione di distribuzione viene quindi distribuita in un ambiente sandbox (non di produzione) AEM as a Cloud Service che non è stato aggiornato per utilizzare una versione AEM che contiene la nuova versione dei componenti core.

Per evitare questo errore, ogni volta che è disponibile un aggiornamento dell’ambiente as a Cloud Service AEM, includi l’aggiornamento come parte della build/distribuzione successiva e assicurati che gli aggiornamenti siano inclusi sempre dopo aver incrementato la versione dei componenti core nella base di codice dell’applicazione.

  • Sintomi:
    Il passaggio Genera immagine non riesce con un messaggio ERROR che segnala che
    com.adobe.cq.wcm.core.components... impossibile importare i pacchetti in intervalli di versioni specifici dal core progetto.

    [ERROR] Bundle com.example.core:0.0.3-SNAPSHOT is importing package(s) Package com.adobe.cq.wcm.core.components.models;version=[12.13,13) in start level 20 but no bundle is exporting these for that start level in the required version range.
    [ERROR] Analyser detected errors on feature 'com.adobe.granite:aem-ethos-app-image:slingosgifeature:aem-runtime-application-publish-dev:1.0.0-SNAPSHOT'. See log output for error messages.
    [INFO] ------------------------------------------------------------------------
    [INFO] BUILD FAILURE
    [INFO] ------------------------------------------------------------------------
    
  • Causa: Il bundle OSGi dell'applicazione (definito nel core progetto) importa le classi Java dalla dipendenza di base dei componenti core, a un livello di versione diverso da quello distribuito a AEM as a Cloud Service.

  • Risoluzione:

    • Utilizzando Git, ripristina un commit di lavoro esistente prima dell’incremento della versione del componente core. Invia questo commit a un ramo Git di Cloud Manager ed esegui un aggiornamento dell’ambiente da questo ramo. Verrà eseguito l’aggiornamento AEM as a Cloud Service alla versione più recente AEM, che includerà la versione più recente dei componenti core. Una volta che l’AEM as a Cloud Service è stato aggiornato all’ultima versione AEM, che avrà l’ultima versione dei componenti core, ridistribuisci il codice originariamente non riuscito.
    • Per riprodurre questo problema localmente, accertati che la versione dell’SDK AEM sia la stessa versione AEM che l’ambiente as a Cloud Service AEM sta utilizzando.

Creare un caso di assistenza per Adobi

Se gli approcci di risoluzione dei problemi sopra descritti non risolvono il problema, crea un caso di assistenza Adobe, tramite:

  • Adobe Admin Console > Scheda Supporto > Crea caso

    Se sei membro di più organizzazioni di Adobe, assicurati che l’organizzazione di Adobe con pipeline non riuscita sia selezionata nel commutatore delle organizzazioni di Adobe prima di creare il caso.

Distribuisci su

Il passaggio Distribuisci a è responsabile dell’artefatto di codice generato in Genera immagine, avvia i nuovi servizi di authoring e pubblicazione AEM che lo utilizzano e, dopo il successo, rimuove tutti i vecchi servizi di authoring e pubblicazione AEM. Anche in questo passaggio vengono installati e aggiornati pacchetti di contenuto variabile e indici.

Acquisisci familiarità con AEM registri as a Cloud Service prima di eseguire il debug del passaggio Distribuisci a . La aemerror Il registro contiene informazioni sull’avvio e lo spegnimento dei pod che possono essere pertinenti a Deploy to issues. Il registro disponibile tramite il pulsante Download Log nel passaggio Distribuzione a di Cloud Manager non è il aemerror registra e non contiene informazioni dettagliate relative all'avvio delle applicazioni.

Distribuisci su

I tre motivi principali per cui il passaggio Distribuisci a potrebbe non riuscire:

La pipeline di Cloud Manager contiene una vecchia versione AEM

  • Causa: Una pipeline di Cloud Manager contiene una versione precedente di AEM rispetto a quella distribuita nell’ambiente di destinazione. Questo può accadere quando una pipeline viene riutilizzata e indirizzata a un nuovo ambiente che esegue una versione successiva di AEM. Questo può essere identificato controllando se la versione AEM dell’ambiente è maggiore della versione AEM della pipeline.
    La pipeline di Cloud Manager contiene una vecchia versione AEM
  • Risoluzione:
    • Se nell’ambiente di destinazione è disponibile un aggiornamento, seleziona Aggiorna dalle azioni dell’ambiente, quindi esegui nuovamente la build.
    • Se nell’ambiente di destinazione non è disponibile un aggiornamento, significa che è in esecuzione la versione più recente di AEM. Per risolvere il problema, elimina la pipeline e ricreala.

Timeout di Cloud Manager

Il codice in esecuzione durante l’avvio del servizio AEM appena implementato richiede così tanto tempo che Cloud Manager riceve un timeout prima del completamento della distribuzione. In questi casi, l’implementazione potrebbe avere successo, anche se lo stato di Cloud Manager segnalava Non riuscito.

  • Causa: Il codice personalizzato può eseguire operazioni, come query di grandi dimensioni o traversate di contenuti, attivate in anticipo nel bundle OSGi o nei cicli di vita dei componenti, ritardando significativamente il tempo di avvio del AEM.
  • Risoluzione: Rivedi l'implementazione del codice che viene eseguito all'inizio del ciclo di vita del bundle OSGi e controlla il aemerror registra i servizi AEM Author e Publish intorno all’ora dell’errore (ora di accesso in GMT) come mostrato da Cloud Manager, e cerca i messaggi di registro che indicano eventuali processi di log personalizzati in esecuzione.

Codice o configurazione non compatibili

La maggior parte delle violazioni del codice e della configurazione vengono rilevate in precedenza nella build, tuttavia è possibile che il codice personalizzato o la configurazione sia incompatibile con l’AEM as a Cloud Service e non venga rilevato finché non viene eseguito nel contenitore .

  • Causa: Il codice personalizzato può richiamare operazioni lunghe, come query di grandi dimensioni o traversate di contenuti, attivate all’inizio nel bundle OSGi o nei cicli di vita dei componenti, rallentando significativamente il tempo di avvio del AEM.
  • Risoluzione: Consulta la sezione aemerror registri dei servizi Author e Publish di AEM intorno all’ora (ora di accesso in GMT) dell’errore, come mostrato da Cloud Manager.
    1. Controlla i registri per eventuali ERRORS generati dalle classi Java fornite dall'applicazione personalizzata. Se vengono rilevati problemi, risolvi, invia il push del codice fisso e ricompila la pipeline.
    2. Controlla i registri per eventuali ERRORS segnalati da aspetti di AEM che stai estendendo/interagendo con nell'applicazione personalizzata e analizzali; questi ERRORI potrebbero non essere direttamente attribuiti alle classi Java. Se vengono rilevati problemi, risolvi, invia il push del codice fisso e ricompila la pipeline.

Inclusione di /var nel pacchetto di contenuti

/var è modificabile contenente una varietà di contenuti transitori e di runtime. Incluso /var in pacchetti di contenuti (ad esempio ui.content) implementata tramite Cloud Manager potrebbe causare il mancato funzionamento del passaggio Distribuzione .

Questo problema è difficile da identificare in quanto non si traduce in un errore nella distribuzione iniziale, solo nelle distribuzioni successive. I sintomi noti includono:

  • La distribuzione iniziale ha esito positivo, indipendentemente dal fatto che il contenuto mutabile, nuovo o modificato, che fa parte della distribuzione, non esista nel servizio AEM Publish.
  • L’attivazione/disattivazione del contenuto in AEM Author è bloccata
  • Le implementazioni successive non riescono nel passaggio Distribuisci a e il passaggio Distribuisci a non riesce dopo circa 60 minuti.

Per convalidare questo problema è la causa del comportamento non riuscito:

  1. Determinando che almeno un pacchetto di contenuto che fa parte della distribuzione, scrive in /var.

  2. Verifica che la coda di distribuzione primaria (in grassetto) sia bloccata in:

    • AEM Author > Strumenti > Implementazione > Distribuzione

      Coda di distribuzione bloccata

  3. In caso di errore nella distribuzione successiva, scarica i registri "Distribuisci a" di Cloud Manager utilizzando il pulsante Download Log (Scarica registro):

    Scarica la distribuzione nei registri

    … e verifica che ci siano circa 60 minuti tra le istruzioni di log:

    2020-01-01T01:01:02+0000 Begin deployment in aem-program-x-env-y-dev [CorrelationId: 1234]
    

    … e …

    2020-01-01T02:04:10+0000 Failed deployment in aem-program-x-env-y-dev
    

    Tieni presente che questo registro non conterrà questi indicatori sulle distribuzioni iniziali che hanno avuto esito positivo, ma solo sulle distribuzioni successive con errori.

  • Causa: AEM'utente del servizio di replica utilizzato per distribuire pacchetti di contenuto al servizio AEM Publish non può scrivere in /var su AEM Publish. Questo causa un errore nella distribuzione del pacchetto di contenuti al servizio AEM Publish.
  • Risoluzione: I seguenti modi per risolvere questi problemi sono elencati in ordine di preferenza:
    1. Se la /var le risorse non sono necessarie per rimuovere le risorse in /var da pacchetti di contenuto distribuiti come parte dell’applicazione.
    2. Se la /var risorse necessarie, definire le strutture dei nodi utilizzando repoinit. Gli script di reindirizzamento possono essere indirizzati a AEM Author, AEM Publish o a entrambi tramite le modalità di esecuzione OSGi.
    3. Se la /var le risorse sono necessarie solo per AEM autore e non possono essere modellate in modo ragionevole utilizzando repoinit, spostali in un pacchetto di contenuti discreti, installato solo su AEM Author da incorporazione nel all in una cartella in modalità di esecuzione di AEM Author (<target>/apps/example-packages/content/install.author</target>).
    4. Fornire ACL appropriati ai sling-distribution-importer utente del servizio come descritto in questo KB Adobe.

Creare un caso di assistenza per Adobi

Se gli approcci di risoluzione dei problemi sopra descritti non risolvono il problema, crea un caso di assistenza Adobe, tramite:

  • Adobe Admin Console > Scheda Supporto > Crea caso

    Se sei membro di più organizzazioni di Adobe, assicurati che l’organizzazione di Adobe con pipeline non riuscita sia selezionata nel commutatore delle organizzazioni di Adobe prima di creare il caso.

In questa pagina