Conflictos de despliegue de MSM msm-rollout-conflicts

Pueden producirse conflictos si se crean nuevas páginas con el mismo nombre en la rama del modelo y en una rama de Live Copy dependiente.

Estos conflictos deben gestionarse y resolverse en el momento del despliegue.

Gestión de conflictos conflict-handling

Cuando existen páginas en conflicto (en las ramas de modelo y Live Copy), MSM le permite definir cómo (o incluso si) deben gestionarse.

Para garantizar que el despliegue no esté bloqueado, las definiciones posibles pueden incluir las siguientes:

  • qué página (modelo o live copy) tiene prioridad durante el despliegue,

  • qué páginas se cambian de nombre (y cómo),

  • cómo afecta esto a cualquier contenido publicado.

    El comportamiento predeterminado de Adobe Experience Manager AEM (de forma predeterminada) es que el contenido publicado no se ve afectado. Por lo tanto, si se ha publicado una página creada manualmente en la rama de Live Copy, ese contenido se sigue publicando después de la gestión y el despliegue del conflicto.

Además de la funcionalidad estándar, se pueden agregar controladores de conflicto personalizados para implementar distintas reglas. También pueden permitir acciones de publicación como un proceso individual.

Escenario de ejemplo example-scenario

En las secciones siguientes, debe utilizar el ejemplo de una nueva página b, creada tanto en el modelo como en la rama de Live Copy (creada manualmente), para ilustrar los distintos métodos de resolución de conflictos:

  • modelo: /b

    Una página maestra; con una página secundaria, bp-level-1.

  • live copy: /b

    Una página creada manualmente en la rama de Live Copy; con una página secundaria, lc-level-1.

    • Se activó al publicar como /b, junto con la página secundaria.

Antes del despliegue

modelo antes del despliegue
live copy antes del despliegue
publicar antes del despliegue
b

(creado en la rama del modelo, listo para su despliegue)
b

(creado manualmente en la rama de live copy)
b

(contiene el contenido de la página b que se creó manualmente en la rama de live copy)
/bp-level-1
/lc-level-1

(creado manualmente en la rama de live copy)
/lc-level-1

(contiene el contenido de la página
child-level-1 que se creó manualmente en la rama de live copy)

Administrador de despliegue y gestión de conflictos rollout-manager-and-conflict-handling

El administrador de despliegue le permite activar o desactivar la administración de conflictos.

Esto se hace con la configuración OSGi del Administrador de despliegue de CQ WCM por día:

  • Controlar conflictos con páginas creadas manualmente:

    ( rolloutmgr.conflicthandling.enabled)

    Se establece en true si el administrador de despliegue debe gestionar los conflictos de una página creada en Live Copy con un nombre que exista en el modelo.

AEM tiene comportamiento predefinido cuando se ha desactivado la administración de conflictos.

Controladores de conflictos conflict-handlers

AEM utiliza controladores de conflictos para resolver cualquier conflicto de páginas que surja al desplegar contenido desde un modelo a una Live Copy. Cambiar el nombre de las páginas es un método (el habitual) para resolver estos conflictos. Puede haber más de un controlador de conflictos en funcionamiento para permitir una selección de comportamientos diferentes.

AEM proporciona lo siguiente:

Controlador de conflictos predeterminado default-conflict-handler

El controlador de conflictos predeterminado:

  • Se llama ResourceNameRolloutConflictHandler

  • Con este controlador, la página de modelo tiene prioridad.

  • La clasificación de servicio de este controlador se establece en un nivel bajo (es decir, por debajo del valor predeterminado para la propiedad service.ranking), ya que se supone que los controladores personalizados necesitan una clasificación más alta. Sin embargo, la clasificación no está al nivel mínimo absoluto para garantizar la flexibilidad cuando sea necesario.

Este controlador de conflictos da prioridad al modelo. La página Live Copy /b se ha movido (dentro de la rama de Live Copy) a /b_msm_moved.

  • live copy: /b

    Se mueve (dentro de la Live Copy) a /b_msm_moved. Esto actúa como una copia de seguridad y garantiza que no se pierda contenido.

    • lc-level-1 no se mueve.
  • modelo: /b

    Se despliega en la página de Live Copy /b.

    • bp-level-1 se ha implementado en la Live Copy.

Después del despliegue

modelo tras el despliegue
live copy después del despliegue
Live Copy después del despliegue
publicar después del despliegue
b
b

(tiene el contenido de la página de modelo b que se desplegó)
b_msm_moved

(tiene el contenido de la página b que se creó manualmente en la rama de live copy)
b

(sin cambios; contiene el contenido de la página original b que se creó manualmente en la rama de live copy y ahora se llama b_msm_move)
/bp-level-1
/bp-level-1
/lc-level-1

(sin cambios)
``
/lc-level-1

(sin cambios)

Controladores personalizados customized-handlers

Los controladores de conflicto personalizados le permiten implementar sus propias reglas. Con el mecanismo de clasificación de servicios también puede definir cómo interactúan con otros controladores.

Los controladores de conflicto personalizados pueden tener lo siguiente:

  • Nombrado según sus necesidades.

  • Desarrollado/configurado según sus necesidades; por ejemplo, puede desarrollar un controlador para que la página de Live Copy tenga prioridad.

  • Diseñado para configurarse con la configuración OSGi; en particular:

    • Clasificación del servicio:

      Define el orden relacionado con otros controladores de conflictos ( service.ranking).

      El valor predeterminado es 0.

Comportamiento Cuando Se Desactiva La Gestión De Conflictos behavior-when-conflict-handling-deactivated

AEM Si desactiva manualmente la administración de conflictos, entonces no realiza ninguna acción en ninguna página en conflicto (las páginas que no entran en conflicto se despliegan según lo esperado).

CAUTION
AEM no da ninguna indicación de que se estén ignorando los conflictos, ya que este comportamiento debe configurarse explícitamente, por lo que se supone que es el comportamiento requerido.

En este caso, la Live Copy tiene prioridad. La página de modelo /b no se copia y la página de Live Copy /b no se modifica.

  • modelo: /b

    No se copia en absoluto y se ignora.

  • live copy: /b

    Lo mismo.

modelo tras el despliegue
Live Copy después del despliegue
publicar después del despliegue
b
b

(sin cambios; tiene el contenido de la página b que se creó manualmente en la rama de live copy)
b

(sin cambios; contiene el contenido de la página b que se creó manualmente en la rama de live copy)
/bp-level-1
/lc-level-1

(sin cambios)
/lc-level-1

(sin cambios)

Clasificación de servicios service-rankings

La clasificación del servicio OSGi se puede utilizar para definir la prioridad de los controladores de conflictos individuales.

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2