Impossible de publier le contenu
Le problème a été corrigé après la réplication de /var/structure de la production à l’environnement intermédiaire et le redémarrage de l’AEM sur les éditeurs intermédiaires.
Description description
Environnement
Adobe Experience Manager (AEM)
Problème
L’éditeur d’évaluation ne fonctionne pas correctement et vous ne pouvez pas publier de contenu sur cette instance.
Les erreurs de ce type sont affichées dans error.log :
20.09.2022 06:53:27.635 *INFO* [ discovery.connectors.common.runner.artewte0-3885-4755-990b-f2d7574839269.discoveryLiteCheck] org.apache.sling.discovery.base.commons.BaseDiscoveryService getTopology: undefined cluster view: REPOSITORY_EXCEPTION] org.apache.sling.discovery.base.commons.UndefinedClusterViewException: Exception while processing descriptor: java.lang.IllegalArgumentException: Can't create child on a synthetic root
20.09.2022 06:53:29.636 *ERROR* [ discovery.connectors.common.runner.a0gfdwsgt0-3885-4755-990b-f2d776738269.discoveryLiteCheck] org.apache.sling.discovery.oak.cluster.OakClusterViewService getLocalClusterView: repository exception: java.lang.IllegalArgumentException: Can't create child on a synthetic root
java.lang.IllegalArgumentException: Can't create child on a synthetic root
at org.apache.sling.resourceresolver.impl.ResourceResolverImpl.create(ResourceResolverImpl.java:979) [ org.apache.sling.resourceresolver:1.7.2.B0001]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResourceInternal(ResourceUtil.java:666) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:603) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:571) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResourceInternal(ResourceUtil.java:654) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:603) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:571) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResourceInternal(ResourceUtil.java:654) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:603) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:571) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResourceInternal(ResourceUtil.java:654) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:603) [ org.apache.sling.api:2.22.0]
at org.apache.sling.api.resource.ResourceUtil.getOrCreateResource(ResourceUtil.java:571) [ org.apache.sling.api:2.22.0]
at org.apache.sling.discovery.commons.providers.util.ResourceHelper.getOrCreateResource(ResourceHelper.java:45) [ org.apache.sling.discovery.commons:1.0.20]
at org.apache.sling.discovery.commons.providers.spi.base.IdMapService.readIdMap(IdMapService.java:302) [ org.apache.sling.discovery.commons:1.0.20]
at org.apache.sling.discovery.commons.providers.spi.base.IdMapService.toSlingId(IdMapService.java:280) [ org.apache.sling.discovery.commons:1.0.20]
at org.apache.sling.discovery.oak.cluster.OakClusterViewService.asClusterView(OakClusterViewService.java:174) [ org.apache.sling.discovery.oak:1.2.22]
at org.apache.sling.discovery.oak.cluster.OakClusterViewService.getLocalClusterView(OakClusterViewService.java:120) [ org.apache.sling.discovery.oak:1.2.22]
at org.apache.sling.discovery.base.commons.BaseDiscoveryService.getTopology(BaseDiscoveryService.java:77) [ org.apache.sling.discovery.base:2.0.8]
at org.apache.sling.discovery.oak.OakDiscoveryService.checkForTopologyChange(OakDiscoveryService.java:660) [ org.apache.sling.discovery.oak:1.2.22]
at org.apache.sling.discovery.oak.pinger.OakViewChecker.discoveryLiteCheck(OakViewChecker.java:217) [ org.apache.sling.discovery.oak:1.2.22]
at org.apache.sling.discovery.oak.pinger.OakViewChecker.access$000(OakViewChecker.java:62) [ org.apache.sling.discovery.oak:1.2.22]
at org.apache.sling.discovery.oak.pinger.OakViewChecker$1.run(OakViewChecker.java:193) [ org.apache.sling.discovery.oak:1.2.22]
at org.apache.sling.discovery.base.commons.PeriodicBackgroundJob.safelyRun(PeriodicBackgroundJob.java:86) [ org.apache.sling.discovery.base:2.0.8]
at org.apache.sling.discovery.base.commons.PeriodicBackgroundJob.run(PeriodicBackgroundJob.java:77) [ org.apache.sling.discovery.base:2.0.8]
at java.base/java.lang.Thread.run(Thread.java:834)
Résolution resolution
L’erreur dans le journal n’est pas liée à la mise en cache, mais elle s’affiche lorsque l’utilisateur du service ne dispose pas des autorisations appropriées pour le chemin /var/discovery
sur l’auteur ou sur l’éditeur.
Lors de la vérification des autorisations pour le chemin d’accès /var/discovery
, il a été constaté qu’il n’y avait pas de dossier discovery
sous /var
sur l’éditeur intermédiaire, et qu’il manquait également beaucoup de contenu.
Alors que le dossier /var
de l’éditeur de production comptait plus de 20 enfants, le dossier /var
de l’éditeur de test n’en avait que 2 : réplication et sling.
Le problème a été corrigé après la réplication de /var/structure
de la production vers l’environnement intermédiaire et le redémarrage de l’AEM sur les éditeurs intermédiaires.