Med AEM as a Cloud Service går Adobe från en AEM instanscentrerad modell till en tjänstebaserad vy med n-x-AEM-behållare, som drivs av CI/CD-pipelines i Cloud Manager. I stället för att konfigurera och underhålla index för enskilda AEM måste indexkonfigurationen anges före en distribution. Konfigurationsförändringar i produktionen bryter helt klart CI/CD-reglerna. Detsamma gäller för indexändringar eftersom det kan påverka systemets stabilitet och prestanda om det inte anges testat och omindexerat innan de tas i produktion.
Nedan finns en lista över de viktigaste ändringarna jämfört med AEM 6.5 och tidigare versioner:
Begränsningar:
lucene
.damAssetLucene
index kan på Skyline faktiskt köras mot en Elasticsearch-version av detta index. Skillnaden är vanligtvis inte synlig för programmet och användaren, men vissa verktyg som explain
funktionen rapporterar ett annat index. Skillnader mellan Lucene-index och Elastic Index finns i den elastiska dokumentationen i Apache Jackrabbit Oak. Kunderna behöver inte, och kan inte, konfigurera Elasticsearch-index direkt.Att definiera index kan omfatta följande tre användningsområden:
För båda punkterna 1 och 2 ovan måste du skapa en ny indexdefinition som en del av din anpassade kodbas i respektive Cloud Manager-utgåva. Mer information finns i Distribuera till AEM as a Cloud Service dokumentation.
En indexdefinition kan vara:
/oak:index/cqPageLucene-2
./oak:index/cqPageLucene-2-custom-1
./oak:index/acme.product-1-custom-2
. För att undvika namnkonflikter kräver vi att helt anpassade index har ett prefix, till exempel acme.
Observera att både anpassning av ett körklart index och helt anpassade index måste innehålla -custom-
. Endast helt anpassade index får börja med ett prefix.
Om du till exempel anpassar ett index som inte finns i kartongen damAssetLucene-6
, please copy the latest out-of-box index definition from a Cloud Service med hjälp av CRX DE Package Manager (/crx/packmgr/
) . Byt sedan namn på konfigurationen, till exempel för att damAssetLucene-6-custom-1
och lägg till anpassningar överst. Detta säkerställer att nödvändiga konfigurationer inte tas bort av misstag. Till exempel tika
nod under /oak:index/damAssetLucene-6/tika
krävs i det anpassade indexvärdet för molntjänsten. Den finns inte i molnet-SDK:n.
Du måste förbereda ett nytt indexdefinitionspaket som innehåller den faktiska indexdefinitionen, enligt namnmönstret:
<indexName>[-<productVersion>]-custom-<customVersion>
som sedan måste gå under ui.apps/src/main/content/jcr_root
. Alla anpassade och anpassade indexdefinitioner måste lagras under /oak:index
.
Filtret för paketet måste anges så att befintliga (ej låsta) index behålls. I filen ui.apps/src/main/content/META-INF/vault/filter.xml
måste varje anpassat (eller anpassat) index listas, till exempel som <filter root="/oak:index/damAssetLucene-6-custom-1"/>
. Om indexversionen ändras senare måste filtret justeras.
Alla innehållspaket som innehåller indexdefinitioner bör ha följande egenskap angiven i egenskapsfilen för innehållspaketet, som finns på /META-INF/vault/properties.xml
:
noIntermediateSaves=true
Indexdefinitioner markeras som anpassade och versionsindelade:
/oak:index/ntBaseLucene-custom-1
)Om du vill distribuera ett anpassat eller anpassat index, indexdefinitionen (/oak:index/definitionname
) måste levereras via ui.apps
via Git och Cloud Manager-distributionsprocessen. I filtret FileVault, till exempel, ui.apps/src/main/content/META-INF/vault/filter.xml
, lista varje anpassat och anpassat index individuellt, till exempel <filter root="/oak:index/damAssetLucene-7-custom-1"/>
. Själva den anpassade/anpassade indexdefinitionen sparas sedan i filen ui.apps/src/main/content/jcr_root/_oak_index/damAssetLucene-7-custom-1/.content.xml
, enligt följande:
<?xml version="1.0" encoding="UTF-8"?>
<jcr:root xmlns:oak="https://jackrabbit.apache.org/oak/ns/1.0" xmlns:dam="http://www.day.com/dam/1.0" xmlns:jcr="http://www.jcp.org/jcr/1.0" xmlns:nt="http://www.jcp.org/jcr/nt/1.0" xmlns:rep="internal"
jcr:primaryType="oak:QueryIndexDefinition"
async="[async,nrt]"
compatVersion="{Long}2"
...
</indexRules>
<tika jcr:primaryType="nt:unstructured">
<config.xml jcr:primaryType="nt:file"/>
</tika>
</jcr:root>
Ovanstående exempel innehåller en konfiguration för Apache Tika. Tika-konfigurationsfilen lagras under ui.apps/src/main/content/jcr_root/_oak_index/damAssetLucene-7-custom-1/tika/config.xml
.
Beroende på vilken version av Jackrabbit Filevault Maven Package Plugin som används krävs en del mer konfiguration i projektet. När du använder Jackrabbit Filevault Maven Package Plugin version 1.1.6 eller nyare, sedan filen pom.xml
måste innehålla följande avsnitt i plugin-konfigurationen för filevault-package-maven-plugin
, in configuration/validatorsSettings
(precis före jackrabbit-nodetypes
):
<jackrabbit-packagetype>
<options>
<immutableRootNodeNames>apps,libs,oak:index</immutableRootNodeNames>
</options>
</jackrabbit-packagetype>
I det här fallet gäller dessutom följande: vault-validation
måste uppgraderas till en nyare version:
<dependency>
<groupId>org.apache.jackrabbit.vault</groupId>
<artifactId>vault-validation</artifactId>
<version>3.5.6</version>
</dependency>
Sedan ui.apps.structure/pom.xml
och ui.apps/pom.xml
, konfigurationen av filevault-package-maven-plugin
måste ha allowIndexDefinitions
och noIntermediateSaves
aktiverat. Alternativet noIntermediateSaves
säkerställer att indexkonfigurationerna läggs till automatiskt.
<groupId>org.apache.jackrabbit</groupId>
<artifactId>filevault-package-maven-plugin</artifactId>
<configuration>
<allowIndexDefinitions>true</allowIndexDefinitions>
<properties>
<cloudManagerTarget>none</cloudManagerTarget>
<noIntermediateSaves>true</noIntermediateSaves>
</properties>
...
I ui.apps.structure/pom.xml
, filters
-avsnittet för det här plugin-programmet måste innehålla en filterrot enligt följande:
<filter><root>/oak:index</root></filter>
När den nya indexdefinitionen har lagts till måste det nya programmet distribueras via Cloud Manager. Vid distributionen startas två jobb som ansvarar för att lägga till (och sammanfoga vid behov) indexdefinitionerna i MongoDB och Azure Segment Store för författare respektive publicering. De underliggande databaserna omindexeras med de nya indexdefinitionerna, innan växlingen äger rum.
Om du observerar följande fel i felvalideringen
[ERROR] ValidationViolation: "jackrabbit-nodetypes: Mandatory child node missing: jcr:content [nt:base] inside node with types [nt:file]"
Därefter kan du åtgärda problemet genom att följa något av följande steg:
<allowIndexDefinitions>true</allowIndexDefinitions>
Nedan visas ett exempel på var ovanstående konfiguration ska placeras i rummet.
<plugin>
<groupId>org.apache.jackrabbit</groupId>
<artifactId>filevault-package-maven-plugin</artifactId>
<configuration>
<properties>
...
</properties>
...
<allowIndexDefinitions>true</allowIndexDefinitions>
<repositoryStructurePackages>
...
</repositoryStructurePackages>
<dependencies>
...
</dependencies>
</configuration>
</plugin>
<isDisabled>true</isDisabled>
Nedan visas ett exempel på var ovanstående konfiguration ska placeras i rummet.
<plugin>
<groupId>org.apache.jackrabbit</groupId>
<artifactId>filevault-package-maven-plugin</artifactId>
...
<configuration>
...
<validatorsSettings>
...
<jackrabbit-nodetypes>
<isDisabled>true</isDisabled>
</jackrabbit-nodetypes>
</validatorsSettings>
</configuration>
</plugin>
Mer information om den paketstruktur som krävs för AEM as a Cloud Service finns i dokumentet AEM projektstruktur.
Indexhantering handlar om att lägga till, ta bort och ändra index. Ändra definition för ett index är snabbt, men det tar lång tid att tillämpa ändringen (kallas ofta"skapa ett index" eller"omindexering" för befintliga index). Det är inte omedelbart: databasen måste genomsökas för att data ska kunna indexeras.
En rullande driftsättning kan minska driftstoppen. Det ger även inga driftavbrott och ger snabba återställningar. Den gamla versionen av programmet körs samtidigt som den nya versionen av programmet.
Vissa delar av databasen (skrivskyddade delar av databasen) kan vara olika i den gamla och den nya versionen av programmet. De skrivskyddade områdena i databasen är vanligtvis /app
och /libs
. I följande exempel används kursiv för att markera skrivskyddade områden, medan fetstil används för skrivskyddade områden.
Databasens läs- och skrivområden delas mellan alla programversioner, medan det för varje programversion finns en specifik uppsättning /apps
och /libs
.
Under utvecklingen, eller vid användning av lokala installationer, kan index läggas till, tas bort eller ändras under körningen. Index används så snart de är tillgängliga. Om ett index inte ska användas i den gamla versionen av programmet än, skapas indexet vanligtvis under en schemalagd driftstopp. Samma sak händer när du tar bort ett index eller ändrar ett befintligt index. När du tar bort ett index blir det otillgängligt så fort det tas bort.
Med rullande driftsättningar sker inga driftavbrott. Under en uppdatering körs både den gamla versionen (till exempel version 1) av programmet och den nya versionen (version 2) samtidigt mot samma databas. Om version 1 kräver att ett visst index är tillgängligt får detta index inte tas bort i version 2. Indexet bör tas bort senare, t.ex. i version 3, där det är garanterat att version 1 av programmet inte längre körs. Dessutom bör program skrivas så att version 1 fungerar bra, även om version 2 körs, och om det finns index för version 2.
När uppgraderingen till den nya versionen är klar kan gamla index samlas in av systemet. De gamla indexen kan fortfarande finnas kvar en tid för att påskynda återställningen (om en återställning behövs).
I följande tabell visas fem indexdefinitioner: index cqPageLucene
används i båda versionerna medan index damAssetLucene-custom-1
används endast i version 2.
<indexName>-custom-<customerVersionNumber>
är nödvändigt för AEM as a Cloud Service att markera detta som en ersättning för ett befintligt index.
Index | Index som inte är tillgängligt | Använd i version 1 | Använd i version 2 |
---|---|---|---|
/oak:index/damAssetLucene | Ja | Ja | Nej |
/oak:index/damAssetLucene-custom-1 | Ja (anpassad) | Nej | Ja |
/oak:index/acme.product-custom-1 | Nej | Ja | Nej |
/oak:index/acme.product-custom-2 | Nej | Nej | Ja |
/oak:index/cqPageLucene | Ja | Ja | Ja |
Versionsnumret ökas stegvis varje gång indexvärdet ändras. För att undvika att egna indexnamn kolliderar med indexnamnen för själva produkten måste anpassade index, liksom ändringar i index utanför rutan, sluta med -custom-<number>
.
När Adobe ändrar ett index som inte finns med i kartongen som "damAssetLucene" eller "cqPageLucene", ett nytt index med namnet damAssetLucene-2
eller cqPageLucene-2
skapas eller, om indexet redan har anpassats, sammanfogas den anpassade indexdefinitionen med ändringarna i det körklara indexet enligt nedan. Ändringarna sammanfogas automatiskt. Det innebär att du inte behöver göra något om ett index som inte finns i kartongen ändras. Det går dock att anpassa indexet igen senare.
Index | Index som inte är tillgängligt | Använd i version 2 | Använd i version 3 |
---|---|---|---|
/oak:index/damAssetLucene-custom-1 | Ja (anpassad) | Ja | Nej |
/oak:index/damAssetLucene-2-custom-1 | Ja (sammanfogas automatiskt från damAssetLucene-custom-1 och damAssetLucene-2) | Nej | Ja |
/oak:index/cqPageLucene | Ja | Ja | Nej |
/oak:index/cqPageLucene-2 | Ja | Nej | Ja |
Indexhantering stöds för närvarande bara för index av typen lucene
, med compatVersion
ange till 2
. Internt kan andra index konfigureras och användas för frågor, till exempel Elasticsearch-index. Frågor som skrivs mot damAssetLucene
på AEM as a Cloud Service kan indexet faktiskt köras mot en Elasticsearch-version av detta index. Skillnaden är osynlig för programslutanvändaren, men vissa verktyg, som explain
funktionen rapporterar ett annat index. Skillnader mellan indexen Lucene och Elasticsearch finns i Elasticsearch dokumentation i Apache Jackrabbit Oak. Kunder kan inte och behöver inte konfigurera Elasticsearch-index direkt.
Endast inbyggda analysatorer stöds (dvs. de som levereras tillsammans med produkten). Anpassade analysatorer stöds inte.
För bästa prestanda bör index inte vara alltför stora. Den totala storleken på alla index kan användas som vägledning: Om detta ökar med mer än 100 % efter att anpassade index har lagts till och standardindex har justerats i en utvecklingsmiljö, bör anpassade indexdefinitioner justeras. AEM as a Cloud Service kan förhindra användning av index som skulle påverka systemets stabilitet och prestanda negativt.
Lägga till ett helt anpassat index med namnet /oak:index/acme.product-custom-1
för att kunna användas i en ny version av programmet och senare, måste indexet konfigureras på följande sätt:
acme.product-1-custom-1
Detta fungerar genom att en anpassad identifierare förskjuts till indexnamnet, följt av en punkt (.
). Identifieraren ska vara mellan 2 och 5 tecken lång.
Som ovan säkerställer detta att indexet bara används av den nya versionen av programmet.
När ett befintligt index ändras måste ett nytt index läggas till med den ändrade indexdefinitionen. Ta till exempel det befintliga indexet /oak:index/acme.product-custom-1
ändras. Det gamla indexet lagras under /oak:index/acme.product-custom-1
och det nya indexet lagras under /oak:index/acme.product-custom-2
.
I den gamla versionen av programmet används följande konfiguration:
/oak:index/acme.product-custom-1
I den nya versionen av programmet används följande (ändrade) konfiguration:
/oak:index/acme.product-custom-2
Indexdefinitioner på AEM as a Cloud Service kanske inte helt matchar indexdefinitionerna på en lokal utvecklingsinstans. Utvecklingsinstansen har ingen Tika-konfiguration, medan AEM as a Cloud Service instanser har en. Om du anpassar ett index med en Tika-konfiguration bör du behålla Tika-konfigurationen.
Ibland behöver en ändring i en indexdefinition återställas. Orsaken kan vara att en ändring har gjorts av misstag eller att en ändring inte längre behövs. Indexdefinitionen damAssetLucene-8-custom-3
skapades av misstag och har redan distribuerats. Därför kanske du vill återgå till den tidigare indexdefinitionen damAssetLucene-8-custom-2
. Om du vill göra det måste du lägga till ett nytt index som kallas damAssetLucene-8-custom-4
som innehåller definitionen av föregående index, damAssetLucene-8-custom-2
.
Följande gäller bara för anpassade index. Produktindex kan inte tas bort eftersom de används av AEM.
Om ett index ska tas bort i en senare version av programmet kan du definiera ett tomt index (ett tomt index som aldrig används och som inte innehåller några data) med ett nytt namn. I det här exemplet kan du ge det ett namn /oak:index/acme.product-custom-3
. Detta ersätter indexvärdet /oak:index/acme.product-custom-2
. En gång /oak:index/acme.product-custom-2
tas bort av systemet, det tomma indexet /oak:index/acme.product-custom-3
kan sedan också tas bort. Ett exempel på ett sådant tomt index är:
<acme.product-custom-3
jcr:primaryType="oak:QueryIndexDefinition"
async="async"
compatVersion="2"
includedPaths="/dummy"
queryPaths="/dummy"
type="lucene">
<indexRules jcr:primaryType="nt:unstructured">
<rep:root jcr:primaryType="nt:unstructured">
<properties jcr:primaryType="nt:unstructured">
<dummy
jcr:primaryType="nt:unstructured"
name="dummy"
propertyIndex="{Boolean}true"/>
</properties>
</rep:root>
</indexRules>
</acme.product-custom-3>
Om det inte längre behövs någon anpassning av ett index som inte finns i kartongen måste du kopiera indexdefinitionen som finns i kartongen. Om du till exempel redan har distribuerat damAssetLucene-8-custom-3
, men behöver inte längre anpassningar och vill växla tillbaka till standardinställningen damAssetLucene-8
index, måste du lägga till ett index damAssetLucene-8-custom-4
som innehåller indexdefinitionen för damAssetLucene-8
.
Apache Jackrabbit Oak möjliggör flexibla indexkonfigurationer för att effektivt hantera sökfrågor. Index är särskilt viktiga för större databaser. Se till att alla frågor backas upp av ett lämpligt index. Frågor utan lämpligt index kan läsa tusentals noder, som sedan loggas som en varning.
Se det här dokumentet för information om hur frågor och index kan optimeras.