Guida all’implementazione della ricerca semplice simple-search-implementation-guide

L’implementazione della ricerca semplice è costituita dai materiali provenienti Adobe Summit lab Ricerca AEM Demistificato. Questa pagina contiene i materiali di questo laboratorio. Per una visita guidata del laboratorio, visualizzare la cartella di lavoro del laboratorio nella sezione Presentazione di questa pagina.

Panoramica dell’architettura di ricerca

Materiale della presentazione bookmarks

Segnalibri bookmarks-1

Strumenti tools

Capitoli chapters

I collegamenti del capitolo riportati di seguito presuppongono Pacchetti iniziali sono installati in AEM Author all’indirizzohttp://localhost:4502

Pacchetti packages

Pacchetti iniziali initial-packages

Pacchetti capitolo chapter-packages

Materiali di riferimento reference-materials

Correzioni e follow-up corrections-and-follow-up

Correzioni e chiarimenti delle discussioni di laboratorio e risposte alle domande di follow-up dei partecipanti.

  1. Come interrompere la reindicizzazione?

    La reindicizzazione può essere interrotta tramite la voce MBean IndexStats disponibile tramite Console web AEM > JMX

  2. In che modo gli indici OAK supportano più tenant?

    Oak supporta il posizionamento di indici all’interno della struttura del contenuto e questi indici indicizzeranno solo all’interno di tale sottostruttura. Ad esempio /content/site-a/oak:index/cqPageLucene può essere creato per indicizzare il contenuto solo in /content/site-a.

    Un approccio equivalente consiste nell'utilizzare includePaths e queryPaths proprietà in un indice in /oak:index. Ad esempio:

    • /oak:index/siteAcqPageLucene@includePaths=/content/site-a
    • /oak:index/siteAcqPageLucene@queryPaths=/content/site-a

    Le considerazioni relative a questo approccio sono le seguenti:

    • Le query DEVONO specificare una restrizione di percorso uguale all'ambito del percorso di query dell'indice oppure essere discendenti di.
    • Indici con ambito più ampio (ad esempio /oak:index/cqPageLucene) indicizzerà ANCHE i dati, con conseguente duplicazione dei costi di acquisizione e utilizzo del disco.
    • Può essere necessaria una gestione duplicativa della configurazione (ad es. l’aggiunta degli stessi indexRules a più indici tenant se questi devono soddisfare gli stessi set di query)
    • Questo approccio è consigliato sul livello di pubblicazione dell’AEM per la ricerca personalizzata del sito, in quanto in AEM Author, è comune che le query vengano eseguite in alto nella struttura del contenuto per tenant diversi (ad esempio, tramite OmniSearch); definizioni di indice diverse possono causare comportamenti diversi solo in base alla restrizione del percorso.
  3. Dove si trova un elenco di tutti gli analizzatori disponibili?

    Oak espone un set di elementi di configurazione dell’analizzatore forniti da Lucene da utilizzare nell’AEM.

  4. Come cercare pagine e risorse nella stessa query?

    Una novità di AEM 6.3 è la possibilità di eseguire query per più tipi di nodo nella stessa query fornita. La seguente query QueryBuilder. Tieni presente che ogni "sottoquery" può risolvere nel proprio indice, quindi in questo esempio, il cq:Page la sottoquery viene risolta in /oak:index/cqPageLucene e dam:Asset la sottoquery viene risolta in /oak:index/damAssetLucene.

    code language-plain
    group.p.or=true
    group.1_group.type=cq:Page
    # add all page restrictions to this group
    group.2_group.type=dam:Asset
    # add all asset restrictions to this group
    

    restituisce il piano di query e query seguente:

    code language-plain
    QUERY:(//element(*, cq:Page) | //element(*, dam:Asset))
    
    PLAN: [cq:Page] as [a] /* lucene:cqPageLucene(/oak:index/cqPageLucene) *:* */ union [dam:Asset] as [a] /* lucene:damAssetLucene(/oak:index/damAssetLucene) *:* */
    

    Esplora la query e i risultati tramite Debugger QueryBuilder e Plug-in AEM Chrome.

  5. Come effettuare ricerche su più percorsi nella stessa query?

    Una novità di AEM 6.3 è la possibilità di eseguire query su più percorsi nella stessa query fornita. La seguente query QueryBuilder. Tieni presente che ogni "sottoquery" può risolvere nel proprio indice.

    code language-plain
    group.p.or=true
    group.1_group.type=cq:Page
    group.1_group.path=/content/docs/en/6-2
    # add all page restrictions to this group
    group.2_group.type=cq:Page
    group.2_group.path=/content/docs/en/6-3
    # add all asset restrictions to this group
    

    restituisce il piano di query e query seguente

    code language-plain
    QUERY: (/jcr:root/content/docs/en/_x0036_-2//element(*, cq:Page) | /jcr:root/content/docs/en/_x0036_-3//element(*, cq:Page))
    
    PLAN: [cq:Page] as [a] /* traverse "/content/docs/en/6-2//*" where isdescendantnode([a], [/content/docs/en/6-2]) */ union [cq:Page] as [a] /* traverse "/content/docs/en/6-3//*" where isdescendantnode([a], [/content/docs/en/6-3]) */
    

    Esplora la query e i risultati tramite Debugger QueryBuilder e Plug-in AEM Chrome.

recommendation-more-help
bb44cebf-d964-4e3c-b64e-ce882243fe4d