Plugin für ElasticSearch (8.4.1) implementiert den Analysator für russische und englische Sprachen, es werden die Wörterbücher des Projekts http://aot.ru verwendet. Das ursprüngliche Plugin wurde von hier übernommen: https://github.com/imotov/elasticsearch -analysis-morphology, das wiederum russian_morphology und english_morphology aus dem Russian Morphology for Apache Lucene-Projekt https://github.com/AKuznetsov/russianmorphology verwendet. Das Plugin fügt zwei Analysatoren hinzu und Token-Filter: „russian_morphology“ und „english_morphology“
Beim Erstellen eines Index geben wir die Einstellungen an, die den Analysator angeben, und erstellen eine Zuordnung basierend auf den Einstellungen. Beispiel
PUT /products
{
"settings": {
"index": {
"analysis": {
"analyzer": {
"product_name_analyzer": {
"type": "custom",
"tokenizer": "standard",
"filter": [
"lowercase",
"search_synonym",
"russian_morphology",
"english_morphology",
"ru_stopwords"
]
}
},
"filter": {
"search_synonym": {
"ignore_case": "true",
"type": "synonym",
"synonyms": [
"bosch,бош"
]
},
"ru_stopwords": {
"type": "stop",
"stopwords": "а,без,более,бы,был,была,были,было,быть,в,вам,вас,весь,во,вот,все,всего,всех,вы,где,да,даже,для,до,его,ее,если,есть,еще,же,за,здесь,и,из,или,им,их,к,как,ко,когда,кто,ли,либо,мне,может,мы,на,надо,наш,не,него,нее,нет,ни,них,но,ну,о,об,однако,он,она,они,оно,от,очень,по,под,при,с,со,так,также,такой,там,те,тем,то,того,тоже,той,только,том,ты,у,уже,хотя,чего,чей,чем,что,чтобы,чье,чья,эта,эти,это,я,a,an,and,are,as,at,be,but,by,for,if,in,into,is,it,no,not,of,on,or,such,that,the,their,then,there,these,they,this,to,was,will,with"
}
}
}
}
},
"mappings": {
"properties": {
"name": {
"type": "text",
"analyzer": "product_name_analyzer"
},
"code": {
"type": "keyword"
},
"description": {
"type": "text",
"analyzer": "product_name_analyzer"
},
"brand": {
"type": "keyword"
}
}
}
}
Ein Bild der ursprünglichen Elasticsearch 8.4.1 mit dem Schritt zur Installation des Analyse-Morphologie-Plugins
Tests nicht implementiert sind, sammeln Sie mvn clean package -Dmaven.test.skip=true
und kopieren Sie dann das resultierende /target/releases/elasticsearch-analysis-morphology-8.4.1.zip in einen vorhandenen Cluster und installieren Sie es über bin/elasticsearch-plugin Installationsdatei: elasticsearch-analysis-morphology-8.4.1.zip