Conflitti di rollout MSM

Possono verificarsi conflitti se vengono create nuove pagine con lo stesso nome di pagina sia nel ramo blueprint che in un ramo Live Copy dipendente.

Tali conflitti devono essere gestiti e risolti al momento del rollout.

Gestione dei conflitti

In presenza di pagine in conflitto (nei rami blueprint e Live Copy), MSM ti consente di definire come (o anche se) devono essere gestite.

Per garantire che il rollout non sia bloccato, le definizioni possibili possono includere:

  • quale pagina (blueprint o Live Copy) avrà priorità durante il rollout,

  • quali pagine verranno rinominate (e come),

  • questo influisce su eventuali contenuti pubblicati.

    Il comportamento predefinito di AEM (preconfigurato) consiste nel fatto che il contenuto pubblicato non sarà interessato. Quindi, se è stata pubblicata una pagina creata manualmente nel ramo Live Copy, il contenuto verrà comunque pubblicato dopo la gestione e il rollout dei conflitti.

Oltre alla funzionalità standard, è possibile aggiungere gestori di conflitti personalizzati per implementare regole diverse. Questi possono anche consentire la pubblicazione di azioni come un singolo processo.

Scenario di esempio

Nelle sezioni seguenti utilizziamo l’esempio di una nuova pagina b, creata sia nella blueprint che nel ramo Live Copy (creata manualmente), per illustrare i vari metodi di risoluzione dei conflitti:

  • blueprint: /b

    Una pagina master; con 1 pagina figlio, bp-level-1.

  • Live Copy: /b

    Una pagina creata manualmente nel ramo Live Copy; con 1 pagina figlio, lc-level-1.

    • Attivato al momento della pubblicazione come /b, insieme alla pagina figlio.

Prima del rollout

blueprint prima del rollout Live Copy prima del rollout pubblicare prima del rollout
b
(creato nel ramo blueprint, pronto per il rollout)
b
(creato manualmente nel ramo Live Copy)
b
(contiene il contenuto della pagina b che è stata creata manualmente nel ramo Live Copy)
/bp-level-1 /lc-level-1
(creato manualmente nel ramo Live Copy)
/lc-level-1
(contiene il contenuto della pagina
child-level-1 creata manualmente nel ramo Live Copy)

Gestione rollout e gestione dei conflitti

Il rollout manager consente di attivare o disattivare la gestione dei conflitti.

Questa operazione viene eseguita utilizzando la configurazione OSGi di Day CQ WCM Rollout Manager:

  • Gestisci i conflitti con le pagine create manualmente:

    ( rolloutmgr.conflicthandling.enabled)

    Imposta su true se il gestore di rollout deve gestire i conflitti di una pagina creata nella Live Copy con un nome esistente nella blueprint.

AEM ha un comportamento predefinito quando la gestione dei conflitti è stata disattivata.

Gestori dei conflitti

AEM utilizza gestori di conflitti per risolvere eventuali conflitti di pagina esistenti durante il rollout del contenuto da una blueprint a una Live Copy. La ridenominazione delle pagine è uno dei metodi più comuni per risolvere tali conflitti. Per consentire la selezione di diversi comportamenti, è possibile utilizzare più gestori di conflitti.

AEM fornisce:

  • Il gestore di conflitti predefinito:

    • ResourceNameRolloutConflictHandler
  • Possibilità di implementare un handler personalizzato.

  • Meccanismo di classificazione del servizio che consente di impostare la priorità di ogni singolo gestore. Viene utilizzato il servizio con la classificazione più alta.

Gestore dei conflitti predefinito

Gestore dei conflitti predefinito:

  • Si chiama ResourceNameRolloutConflictHandler

  • Con questo gestore la pagina blueprint ha la precedenza.

  • La classificazione del servizio per questo gestore è impostata su bassa ( "cioè al di sotto del valore predefinito per la proprietà service.ranking , poiché si presuppone che i gestori personalizzati necessitino di una classificazione più elevata. Tuttavia, la classificazione non è il minimo assoluto per garantire flessibilità quando necessario.

Questo gestore di conflitti ha la precedenza sulla blueprint. La pagina Live Copy /b viene spostata (all’interno del ramo Live Copy) in /b_msm_moved.

  • Live Copy: /b

    Viene spostato (all’interno della Live Copy) in /b_msm_moved. Questo funge da backup e assicura che non venga perso alcun contenuto.

    • lc-level-1 non viene spostato.
  • blueprint: /b

    Viene eseguito il rollout nella pagina Live Copy /b.

    • bp-level-1 viene implementato nella Live Copy.

Dopo il rollout

blueprint dopo il rollout live copy dopo il rollout
live copy dopo il rollout


pubblicare dopo il rollout

b b
(presenta il contenuto della pagina blueprint b che è stata implementata)
b_msm_moved
(presenta il contenuto della pagina b che è stata creata manualmente nel ramo Live Copy)
b
(nessuna modifica; contiene il contenuto della pagina originale b creato manualmente nel ramo Live Copy e ora denominato b_msm_move)
/bp-level-1 /bp-level-1 /lc-level-1
(nessuna modifica)
/lc-level-1
(nessuna modifica)

Gestori personalizzati

I gestori di conflitti personalizzati ti consentono di implementare regole personalizzate. Utilizzando il meccanismo di classificazione del servizio è inoltre possibile definire il modo in cui interagiscono con altri gestori.

I gestori di conflitti personalizzati possono:

  • Fai un nome in base alle tue esigenze.

  • essere sviluppati/configurati in base alle proprie esigenze; ad esempio, puoi sviluppare un gestore in modo che la pagina Live Copy abbia la precedenza.

  • Può essere progettato per essere configurato utilizzando la configurazione OSGi; in particolare:

    • Classifica servizi:

      Definisce l'ordine relativo ad altri gestori di conflitti ( service.ranking).

      Il valore predefinito è 0.

Comportamento quando la gestione dei conflitti è disattivata

Se si disattiva manualmente la gestione dei conflitti, AEM non esegue alcuna azione su alcuna pagina in conflitto (le pagine non in conflitto vengono distribuite come previsto).

ATTENZIONE

AEM non fornisce alcuna indicazione che i conflitti vengono ignorati in quanto questo comportamento deve essere configurato in modo esplicito, quindi si presume che sia il comportamento richiesto.

In questo caso la Live Copy ha effettivamente la precedenza. La pagina blueprint /b non viene copiata e la pagina Live Copy /b non viene toccata.

  • blueprint: /b

    Non viene copiato, ma viene ignorato.

  • Live Copy: /b

    Rimane lo stesso.

Dopo il rollout
blueprint dopo il rollout live copy dopo il rollout


pubblicare dopo il rollout

b b
(nessuna modifica; ha il contenuto della pagina b che è stata creata manualmente nel ramo Live Copy)
b
(nessuna modifica; contiene il contenuto della pagina b che è stata creata manualmente nel ramo Live Copy)
/bp-level-1 /lc-level-1
(nessuna modifica)
/lc-level-1
(nessuna modifica)

Classificazioni di servizio

La classificazione del servizio OSGi può essere utilizzata per definire la priorità dei singoli gestori di conflitti.

In questa pagina