Sincronización de usuarios

Última actualización: 2024-01-08

Introducción

Cuando la implementación es una publicar conjunto de servidores, los miembros deben poder iniciar sesión y ver sus datos en cualquier nodo de publicación.

Los usuarios y grupos de usuarios (datos de usuario) creados en el entorno de publicación no son necesarios en el entorno de creación.

La mayoría de los datos de usuario creados en el entorno de autor están pensados para permanecer en el entorno de autor y no para copiarse en las instancias de publicación.

El registro y las modificaciones realizadas en una instancia de publicación deben sincronizarse con otras instancias de publicación para que tengan acceso a los mismos datos de usuario.

AEM A partir de la versión 6.1, cuando la sincronización de usuarios está habilitada, los datos de usuario se sincronizan automáticamente en las instancias de publicación de la granja y no se crean en el autor.

Distribución de Sling

Los datos de usuario, junto con sus ACL, se almacenan en Oak Core, la capa debajo de Oak JCR y se accede a ellas mediante la variable API de Oak. Con actualizaciones poco frecuentes, es razonable que los datos de usuario se sincronicen con otras instancias de publicación mediante Sling Content Distribution (Distribución de Sling).

Las ventajas de la sincronización de usuarios mediante la distribución Sling en comparación con la replicación tradicional son las siguientes:

  • usuarios, perfiles de usuario, y grupos de usuarios Las páginas creadas en Publish no se crean en Author

  • La distribución de Sling establece propiedades en eventos jcr, lo que permite actuar dentro de detectores de eventos de publicación sin preocuparse por los bucles de replicación infinitos

  • La distribución de Sling solo envía datos de usuario a instancias de publicación no originarias, lo que elimina el tráfico innecesario

  • ACL Los conjuntos de en el nodo de usuario se incluyen en la sincronización

NOTA

Si son necesarias sesiones, se recomienda utilizar una solución SSO o una sesión fija y hacer que los clientes inicien sesión si se les cambia a otra instancia de publicación.

PRECAUCIÓN

Sincronización del administradores no se admite el grupo, incluso cuando la sincronización de usuarios está habilitada. En su lugar, se registra un error al "importar la comparación de diferencias" en el registro de errores.

Por lo tanto, cuando la implementación es un conjunto de servidores de publicación, si se agrega o se quita un usuario del administradores , la modificación debe realizarse manualmente en cada instancia de publicación.

Activar sincronización de usuarios

NOTA

De forma predeterminada, la sincronización de usuarios es disabled.

Habilitar la sincronización de usuarios implica modificar existente Configuraciones de OSGi.

No se deben agregar nuevas configuraciones como resultado de habilitar la sincronización del usuario.

La sincronización de usuarios se basa en el entorno de creación para administrar las distribuciones de datos de usuario, aunque los datos de usuario no se creen en el entorno de creación. Gran parte de la configuración, pero no toda, tiene lugar en el entorno de creación y cada paso identifica claramente si se va a realizar en Autor o Publicación.

A continuación se indican los pasos necesarios para habilitar la sincronización de usuarios, seguidos de un Solución de problemas sección:

Requisitos previos

  1. Si ya se han creado usuarios y grupos de usuarios en una instancia de publicación, se recomienda sincronización manual Agregue los datos de usuario a todas las instancias de publicación antes de configurar y habilitar la sincronización de usuarios.

Una vez habilitada la sincronización de usuarios, solo se sincronizan los usuarios y grupos recién creados.

  1. Asegúrese de que está instalado el código más reciente:

1. Agente de distribución de Apache Sling: fábrica de agentes de sincronización

Habilitar sincronización de usuarios

  • sobre el autor

    • iniciar sesión con privilegios de administrador

    • acceda al Consola web

    • localizar Apache Sling Distribution Agent - Sync Agents Factory

      • seleccione la configuración existente para poder abrirla y editarla (icono de lápiz) Verificar name: socialpubsync

      • seleccione el Enabled casilla de verificación

      • select Save

Agente de distribución de Apache Sling

2. Crear usuario autorizado

Configuración de permisos

El usuario autorizado se utiliza en el paso 3 para configurar la distribución de Sling en Autor.

PRECAUCIÓN

Se debe crear un nuevo usuario.

  • El usuario predeterminado asignado es admin.
  • No use communities-user-admin user.

Cómo añadir ACL

  • CRXDE Lite de acceso

  • select /home nodo

  • en el panel derecho, seleccione Access Control pestaña

  • para añadir una entrada ACL, seleccione la + botón

    • Principal: buscar usuario creado para sincronización de usuarios
    • Tipo: Allow
    • Privilegios: jcr:all
    • Restricciones representante:glob: */activities/*
    • select OK
  • select Guardar todo

Agregar ventana ACL

Consulte también

3. Adobe Granite Distribution - Proveedor secreto de transporte con contraseña cifrada

Configuración de permisos

Una vez que sea usuario autorizado (un miembro de) administrators Cuando el grupo de usuarios se crea en todas las instancias de publicación, el usuario autorizado debe identificarse en Autor como con permiso para sincronizar los datos de usuario de Autor a Publicar.

  • en Autor

    • iniciar sesión con privilegios de administrador

    • acceda al Consola web

    • localizar com.adobe.granite.distribution.core.impl.CryptoDistributionTransportSecretProvider.name

    • para abrir y editar, seleccione la configuración existente (icono de lápiz) Verificar property name: socialpubsync-publishUser

    • establezca el nombre de usuario y la contraseña en usuario autorizado creado al publicar en el paso 2

      • por ejemplo, usersync-admin

Proveedor secreto de transporte de contraseña cifrada

4. Agente de distribución de Apache Sling: fábrica de agentes de cola

Habilitar sincronización de usuarios

  • en cada instancia de Publish:

    • iniciar sesión con privilegios de administrador

    • acceda al Consola web

    • localizar Apache Sling Distribution Agent - Queue Agents Factory

      • para abrir y editar, seleccione la configuración existente (icono de lápiz) Verificar Name: socialpubsync-reverse

      • seleccione el Enabled casilla de verificación

      • select Save

    • repetir para cada instancia de Publish

Fábrica de agentes de cola

5. Adobe Social Sync - Diff Observer Factory

Habilitar sincronización de grupos

  • en cada instancia de Publish:

    • iniciar sesión con privilegios de administrador

    • acceda al Consola web

    • localizar Adobe Social Sync - Diff Observer Factory

      • para abrir y editar, seleccione la configuración existente (icono de lápiz)

        Verificar agent name: socialpubsync-reverse

      • seleccione el Enabled casilla de verificación

      • select Save

Diff Observer Factory

6. Déclencheur de distribución de Apache Sling: fábrica de Déclencheur programados

(Opcional) modificar intervalo de sondeo

De forma predeterminada, el autor sondea los cambios cada 30 segundos. Para modificar este intervalo:

  • en Autor

    • iniciar sesión con privilegios de administrador

    • acceda al Consola web

    • localizar Apache Sling Distribution Trigger - Scheduled Triggers Factory

      • para abrir y editar, seleccione la configuración existente (icono de lápiz)

        • Verificar Name: socialpubsync-scheduled-trigger
      • configure el Interval in Seconds hasta el intervalo deseado

      • select Save

Déclencheur programados de fábrica

Configurar para varias instancias de publicación

La configuración predeterminada es para una sola instancia de publicación. Dado que el motivo para habilitar la sincronización de usuarios es sincronizar varias instancias de publicación, como para un conjunto de servidores de publicación, las instancias de publicación adicionales deben agregarse a la fábrica de agentes de sincronización.

7. Agente de distribución de Apache Sling: fábrica de agentes de sincronización

Añadir instancias de publicación:

  • en Autor

    • iniciar sesión con privilegios de administrador

    • acceda al Consola web

    • localizar Apache Sling Distribution Agent - Sync Agents Factory

      • para abrir y editar, seleccione la configuración existente (icono de lápiz) Verificar Name: socialpubsync

Fábrica de agentes de sincronización

  • Extremos del exportador
    Debe haber un extremo de exportador para cada instancia de publicación. Por ejemplo, si hay 2 instancias de publicación, localhost:4503 y 4504, debe haber dos entradas:

    • https://localhost:4503/libs/sling/distribution/services/exporters/socialpubsync-reverse
    • https://localhost:4504/libs/sling/distribution/services/exporters/socialpubsync-reverse
  • Extremos del importador
    Debe haber un extremo de importador para cada instancia de publicación. Por ejemplo, si hay 2 instancias de publicación, localhost:4503 y 4504, debe haber dos entradas:

    • https://localhost:4503/libs/sling/distribution/services/importers/socialpubsync
    • https://localhost:4504/libs/sling/distribution/services/importers/socialpubsync
  • select Save

8. Receptor de sincronización de usuarios de AEM Communities

(Opcional) Sincronizar nodos JCR adicionales

Si hay datos personalizados para sincronizar en varias instancias de publicación, haga lo siguiente:

  • en cada instancia de Publish:

    • iniciar sesión con privilegios de administrador

    • acceda al Consola web

      • por ejemplo, https://localhost:4503/system/console/configMgr
    • localizar AEM Communities User Sync Listener

    • para abrir y editar, seleccione la configuración existente (icono de lápiz) Verificar Name: socialpubsync-scheduled-trigger

Receptor de sincronización de usuarios de AEM Communities

  • Tipos de nodo
    Esta es la lista de tipos de nodos sincronizados. Cualquier tipo de nodo que no sea sling:Folder debe enumerarse aquí (sling:folder se administra por separado).
    Lista predeterminada de tipos de nodos para sincronizar:

    • rep:Usuario
    • nt:unstructured
    • nt:resource
  • Propiedades ignorables
    Esta es la lista de propiedades que se omiten si se detecta algún cambio. Los cambios en estas propiedades pueden sincronizarse como efecto secundario de otros cambios (ya que la sincronización siempre se realiza en el nivel de nodo), pero los cambios en estas propiedades no afectan, por sí solos, a la sincronización de déclencheur.
    Propiedad predeterminada para omitir:

    • cq:lastModified
  • Nodos ignorables
    Subrutas que se ignoran durante la sincronización. No se sincroniza nada en estas subrutas en ningún momento.
    Nodos predeterminados para omitir:

    • .tokens
    • sistema
  • Carpetas distribuidas
    La mayoría de sling:Folders se omiten porque la sincronización no es necesaria. Las pocas excepciones se enumeran aquí.
    Carpetas predeterminadas para sincronizar

    • segmentos/puntuación
    • social/relaciones
    • actividades

9. ID único de Sling

PRECAUCIÓN

Si el ID de Sling coincide entre dos o más instancias de publicación, se produce un error en la sincronización de grupos de usuarios.

Si el ID de Sling es el mismo para varias instancias de publicación en un conjunto de servidores de publicación, los grupos de usuarios no se sincronizan.

Para validar que todos los valores de ID de Sling son diferentes, en cada instancia de publicación:

  1. examinar a http://<host>:<port>/system/console/status-slingsettings
  2. compruebe el valor de ID de Sling

Comprobación del valor del ID de Sling

Si el ID de Sling de una instancia de publicación coincide con el ID de Sling de cualquier otra instancia de publicación, haga lo siguiente:

  1. detenga una de las instancias de publicación que tenga un ID de Sling coincidente

  2. en el directorio crx-quickstart/launchpad/felix

    • busque y elimine el archivo llamado sling.id.file

      • por ejemplo, en un sistema Linux®:

        rm -i $(find . -type f -name sling.id.file)

      • por ejemplo, en un sistema Windows:

        use windows explorer and search for *sling.id.file*

  3. inicio de la instancia de publicación

    • al inicio se le asigna un nuevo ID de Sling
  4. validar que la variable ID de Sling es ahora único

Repita estos pasos hasta que todas las instancias de publicación tengan un ID de Sling único.

Generador de paquetes Vault Factory

Para que las actualizaciones se sincronicen correctamente, es necesario modificar el generador de paquetes Vault para la sincronización de usuarios:

  • AEM en cada instancia de publicación de la

  • acceda al Consola web

  • busque el Apache Sling Distribution Packaging - Vault Package Builder Factory

    • Builder name: socialpubsync-vlt
  • seleccione el icono de edición

  • añadir dos Package Node Filters:

    • /home/users|-.*/.tokens
    • /home/users|-.*/rep:cache
  • administración de directivas:

    • para sobrescribir los nodos rep:policy existentes con otros nuevos, agregue un tercer filtro de paquetes:

      • /home/users|+.*/rep:policy
    • para evitar que se distribuyan directivas, establezca

      • Acl Handling: IGNORE

Generador de paquetes Vault Factory

¿Qué sucede cuando…?

El usuario se registra automáticamente o edita el perfil al publicar

Por diseño, los usuarios y perfiles creados en el entorno de publicación (registro automático) no aparecen en el entorno de creación.

Cuando la topología es un publicar conjunto de servidores y la sincronización del usuario se ha configurado correctamente, el usuario y perfil de usuario se sincroniza en el conjunto de servidores de publicación mediante la distribución Sling.

Los usuarios o grupos de usuarios se crean mediante la consola de seguridad

Por diseño, los datos de usuario creados en el entorno de publicación no aparecen en el entorno de creación y a la inversa.

Si la variable Administración de usuarios y seguridad se utiliza para agregar nuevos usuarios en el entorno de publicación, la sincronización de usuarios sincroniza los nuevos usuarios y su pertenencia a grupos con otras instancias de publicación, si es necesario. La sincronización de usuarios también sincroniza los grupos de usuarios creados mediante la consola de seguridad.

Solución de problemas

Cómo quitar la sincronización de usuarios sin conexión

Para quitar la sincronización de usuarios sin conexión, vaya a quitar una instancia de Publish o sincronización manual de datos, la cola de distribución debe estar vacía y silenciosa.

Para comprobar el estado de la cola de distribución:

  • en Autor:

    • usando CRXDE Lite

      • buscar entradas en /var/sling/distribution/packages

        • nodos de carpeta llamados con el patrón distrpackage_*
    • usando Administrador de paquetes

      • buscar paquetes pendientes (aún no instalados)

        • con el nombre del patrón socialpubsync-vlt*
        • creado por communities-user-admin

Cuando la cola de distribución está vacía, deshabilitar la sincronización de usuarios:

Cuando finalice las tareas, para volver a habilitar la sincronización de usuarios:

Diagnóstico de sincronización de usuario

Diagnóstico de sincronización de usuarios es una herramienta que comprueba la configuración e intenta identificar cualquier problema.

En Autor, simplemente navegue desde la consola principal a través de Herramientas, Operaciones, Diagnóstico, Diagnóstico de sincronización de usuarios.

Los resultados se muestran al entrar en la consola Diagnóstico de sincronización de usuarios.

Esto es lo que se muestra cuando la sincronización de usuarios no se ha habilitado:

Advertencia de que Diagnóstico de sincronización de usuarios no está habilitado

Cómo ejecutar diagnósticos para instancias de publicación

Cuando el diagnóstico se ejecuta desde el entorno de creación, los resultados de aprobado/suspenso incluyen un [INFORMACIÓN] que muestra la lista de instancias de publicación configuradas para su confirmación.

En la lista se incluye una dirección URL para cada instancia de publicación que ejecuta los diagnósticos para esa instancia. El parámetro de URL syncUser se anexa a la dirección URL de diagnóstico con su valor establecido en usuario de sincronización autorizado creado en Paso 2.

Nota: antes de iniciar la URL, el usuario de sincronización autorizado ya debe estar conectado a esa instancia de publicación.

Diagnóstico para instancias de publicación

Configuración añadida incorrectamente

Cuando la sincronización del usuario no funciona, el problema más común es que se han realizado configuraciones adicionales añadido. En su lugar, la configuración predeterminada *existente debería haber sido editado.

A continuación, se muestran vistas de cómo deben aparecer las configuraciones predeterminadas editadas en la consola web. Si aparece más de una instancia, la configuración añadida debería eliminarse.

(Autor) Un agente de distribución de Apache Sling: fábrica de agentes de sincronización

Vista de configuraciones predeterminadas editadas en la consola web

(Autor) Credenciales de transporte de distribución de Apache Sling: credenciales de usuario basadas en DistributionTransportSecretProvider

Vista de configuraciones predeterminadas editadas en la consola web

(Publicar) Un agente de distribución de Apache Sling: fábrica de agentes de cola

Vista de configuraciones predeterminadas editadas en la consola web

(Publicar) One Adobe Social Sync - Diff Observer Factory

Vista de configuraciones predeterminadas editadas en la consola web

(Autor) Un Déclencheur de distribución de Apache Sling: fábrica de Déclencheur programados

Vista de configuraciones predeterminadas editadas en la consola web

Modificar Excepción De Operación Durante El Procesamiento De Respuesta

Si lo siguiente es visible en el registro:

org.apache.sling.servlets.post.impl.operations.ModifyOperation Exception during response processing.

java.lang.IllegalStateException: This tree does not exist

A continuación, compruebe que la sección 2. Crear usuario autorizado se ha seguido correctamente.

En esta sección se describe la creación de un usuario autorizado, que existe en todas las instancias de publicación, y su identificación en la configuración OSGi del "Proveedor secreto" en Autor. De forma predeterminada, el usuario es admin.

El usuario autorizado debe convertirse en miembro de administrators el grupo de usuarios y los permisos para ese grupo no deben modificarse.

El usuario autorizado debe tener explícitamente los siguientes privilegios y restricciones en todas las instancias de publicación:

ruta jcr:todo rep:glob
/home X */activities/*
/home/users X */activities/*
/home/groups X */activities/*

Como miembro de la administrators , el usuario autorizado debe tener los siguientes privilegios en todas las instancias de publicación:

ruta jcr:todo jcr:leer rep:write
/etc/packages/sling/distribution X
/libs/sling/distribution X
/var X
/var/eventing X X
/var/sling/distribution X X

Error de sincronización de grupo de usuarios

Si el ID de Sling coincide entre dos o más instancias de publicación, se produce un error en la sincronización de grupos de usuarios.

Consulte la sección 9. ID único de Sling

Sincronización manual de usuarios y grupos de usuarios

Para configurar o habilitar la sincronización de usuarios, vaya al paso 1: Agente de distribución de Apache Sling: fábrica de agentes de sincronización

Cuando una instancia de publicación deja de estar disponible

Cuando una instancia de publicación deja de estar disponible, no debe eliminarse si vuelve a conectarse en el futuro. Los cambios se ponen en cola para la instancia de publicación y, cuando vuelve a estar en línea, se procesan.

Si la instancia de publicación nunca vuelve a conectarse, si está sin conexión de forma permanente, debe eliminarse porque la acumulación de colas provoca un uso notable del espacio en disco en el entorno de creación.

Cuando una instancia de publicación está desactivada, el registro de autor tiene excepciones similares a las siguientes:

28.01.2016 15:57:48.475 ERROR
 [pool-12-thread-34-org_apache_sling_distribution_queue_socialpubsync_endpoint1
 (org/apache/sling/distribution/queue/socialpubsync/endpoint1)]
 org.apache.sling.distribution.agent.impl.SimpleDistributionAgent [agent][socialpubsync] could not deliver package distrpackage_1454014575838_a2b45ec8-0400-42f3-bed8-ae09b66381cb
 org.apache.sling.distribution.packaging.DistributionPackageImportException: failed in importing package ...

Eliminación de una instancia de publicación

Para quitar una instancia de publicación de Agente de distribución de Apache Sling: fábrica de agentes de sincronización, la cola de distribución debe estar vacía y silenciosa.

En esta página