I-Elasticsearch iyinjini yokusesha ene-json rest api, isebenzisa i-Lucene futhi ibhalwe nge-Java. Incazelo yazo zonke izinzuzo zale njini itholakala ku . Ngokulandelayo sizobhekisela ku-Elasticsearch njenge-ES.
Izinjini ezifanayo zisetshenziselwa ukusesha okuyinkimbinkimbi kusizindalwazi sedokhumenti. Isibonelo, sesha ngokunaka imofology yolimi noma sesha ngama-geo coordinates.
Kulesi sihloko ngizokhuluma ngezisekelo ze-ES usebenzisa isibonelo sokukhomba okuthunyelwe kwebhulogi. Ngizokubonisa indlela yokuhlunga, ukuhlunga nokusesha amadokhumenti.
Ukuze nginganciki ohlelweni lokusebenza, ngizokwenza zonke izicelo ku-ES ngisebenzisa i-CURL. Kukhona ne-plugin ye-google chrome ebizwa .
Umbhalo uqukethe izixhumanisi eziya kumadokhumenti neminye imithombo. Ekugcineni kukhona izixhumanisi zokufinyelela ngokushesha kumadokhumenti. Izincazelo zamagama angajwayelekile zingatholakala ku .
Ifaka i-ES
Ukuze senze lokhu, sidinga kuqala i-Java. Onjiniyela faka izinguqulo ze-Java ezintsha kune-Java 8 update 20 noma Java 7 update 55.
Ukusabalalisa kwe-ES kuyatholakala ku- . Ngemuva kokukhipha ingobo yomlando udinga ukuyiqalisa bin/elasticsearch. Iyatholakala futhi . Kukhona . .
Ngemva kokufaka nokwethulwa, ake sihlole ukusebenza:
# Π΄Π»Ρ ΡΠ΄ΠΎΠ±ΡΡΠ²Π° Π·Π°ΠΏΠΎΠΌΠ½ΠΈΠΌ Π°Π΄ΡΠ΅Ρ Π² ΠΏΠ΅ΡΠ΅ΠΌΠ΅Π½Π½ΡΡ
#export ES_URL=$(docker-machine ip dev):9200
export ES_URL=localhost:9200
curl -X GET $ES_URLSizothola okuthile okufana nalokhu:
{
"name" : "Heimdall",
"cluster_name" : "elasticsearch",
"version" : {
"number" : "2.2.1",
"build_hash" : "d045fc29d1932bce18b2e65ab8b297fbf6cd41a1",
"build_timestamp" : "2016-03-09T09:38:54Z",
"build_snapshot" : false,
"lucene_version" : "5.4.1"
},
"tagline" : "You Know, for Search"
}Ukwenza inkomba
Ake sengeze okuthunyelwe ku-ES:
# ΠΠΎΠ±Π°Π²ΠΈΠΌ Π΄ΠΎΠΊΡΠΌΠ΅Π½Ρ c id 1 ΡΠΈΠΏΠ° post Π² ΠΈΠ½Π΄Π΅ΠΊΡ blog.
# ?pretty ΡΠΊΠ°Π·ΡΠ²Π°Π΅Ρ, ΡΡΠΎ Π²ΡΠ²ΠΎΠ΄ Π΄ΠΎΠ»ΠΆΠ΅Π½ Π±ΡΡΡ ΡΠ΅Π»ΠΎΠ²Π΅ΠΊΠΎ-ΡΠΈΡΠ°Π΅ΠΌΡΠΌ.
curl -XPUT "$ES_URL/blog/post/1?pretty" -d'
{
"title": "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΠΊΠΎΡΡΡΠ°",
"content": "<p>Π‘ΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ ΠΊΠΎΡΡΡ<p>",
"tags": [
"ΠΊΠΎΡΡΡΠ°",
"ΡΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ"
],
"published_at": "2014-09-12T20:44:42+00:00"
}'
impendulo yeseva:
{
"_index" : "blog",
"_type" : "post",
"_id" : "1",
"_version" : 1,
"_shards" : {
"total" : 2,
"successful" : 1,
"failed" : 0
},
"created" : false
}
I-ES idalwe ngokuzenzakalelayo blog kanye okuthunyelwe. Singadweba isifaniso esinemibandela: inkomba iyisizindalwazi, futhi uhlobo luyithebula kulesi sizindalwazi. Uhlobo ngalunye lunohlelo lwalo β , njengetafula lobudlelwano. Ukwenza imephu kukhiqizwa ngokuzenzakalelayo lapho idokhumenti ikhonjisiwe:
# ΠΠΎΠ»ΡΡΠΈΠΌ mapping Π²ΡΠ΅Ρ
ΡΠΈΠΏΠΎΠ² ΠΈΠ½Π΄Π΅ΠΊΡΠ° blog
curl -XGET "$ES_URL/blog/_mapping?pretty"Empendulweni yeseva, ngengeze amanani ezinkambu zedokhumenti enenkomba kumazwana:
{
"blog" : {
"mappings" : {
"post" : {
"properties" : {
/* "content": "<p>Π‘ΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ ΠΊΠΎΡΡΡ<p>", */
"content" : {
"type" : "string"
},
/* "published_at": "2014-09-12T20:44:42+00:00" */
"published_at" : {
"type" : "date",
"format" : "strict_date_optional_time||epoch_millis"
},
/* "tags": ["ΠΊΠΎΡΡΡΠ°", "ΡΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ"] */
"tags" : {
"type" : "string"
},
/* "title": "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΠΊΠΎΡΡΡΠ°" */
"title" : {
"type" : "string"
}
}
}
}
}
}Kubalulekile ukuqaphela ukuthi i-ES ayihlukanisi phakathi kwevelu eyodwa kanye nohlu lwamanani. Isibonelo, inkambu yesihloko imane iqukethe isihloko, futhi inkambu yomaka iqukethe uchungechunge lwezintambo, nakuba zimelelwe ngendlela efanayo kumephu.
Sizokhuluma kabanzi mayelana nokwenza imephu kamuva.
Izicelo
Ibuyisa idokhumenti nge-id yayo:
# ΠΈΠ·Π²Π»Π΅ΡΠ΅ΠΌ Π΄ΠΎΠΊΡΠΌΠ΅Π½Ρ Ρ id 1 ΡΠΈΠΏΠ° post ΠΈΠ· ΠΈΠ½Π΄Π΅ΠΊΡΠ° blog
curl -XGET "$ES_URL/blog/post/1?pretty"{
"_index" : "blog",
"_type" : "post",
"_id" : "1",
"_version" : 1,
"found" : true,
"_source" : {
"title" : "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΠΊΠΎΡΡΡΠ°",
"content" : "<p>Π‘ΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ ΠΊΠΎΡΡΡ<p>",
"tags" : [ "ΠΊΠΎΡΡΡΠ°", "ΡΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ" ],
"published_at" : "2014-09-12T20:44:42+00:00"
}
}Okhiye abasha bavele empendulweni: _version ΠΈ _source. Ngokuvamile, zonke izinkinobho ziqala _ zihlukaniswa njengezisemthethweni.
Ukhiye _version ibonisa inguqulo yedokhumenti. Kudingeka ukuze indlela yokukhiya enethemba isebenze. Isibonelo, sifuna ukushintsha idokhumenti enenguqulo 1. Sihambisa idokhumenti eshintshiwe futhi sibonisa ukuthi lokhu kuwukuhlelwa kwedokhumenti enenguqulo 1. Uma omunye futhi ehlele idokhumenti enenguqulo 1 futhi wahambisa izinguquko phambi kwethu, khona-ke. I-ES ngeke yamukele izinguquko zethu, ngoba igcina idokhumenti nenguqulo 2.
Ukhiye _source iqukethe idokhumenti esiyikhombile. I-ES ayisebenzisi leli nani emisebenzini yosesho ngoba Izinkomba zisetshenziselwa ukusesha. Ukuze wonge isikhala, i-ES igcina idokhumenti yomthombo ecindezelwe. Uma sidinga kuphela i-id, hhayi yonke idokhumenti yomthombo, lapho-ke singakhubaza isitoreji somthombo.
Uma singadingi ulwazi olwengeziwe, singathola kuphela okuqukethwe _komthombo:
curl -XGET "$ES_URL/blog/post/1/_source?pretty"{
"title" : "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΠΊΠΎΡΡΡΠ°",
"content" : "<p>Π‘ΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ ΠΊΠΎΡΡΡ<p>",
"tags" : [ "ΠΊΠΎΡΡΡΠ°", "ΡΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ" ],
"published_at" : "2014-09-12T20:44:42+00:00"
}
Ungaphinda ukhethe izinkambu ezithile kuphela:
# ΠΈΠ·Π²Π»Π΅ΡΠ΅ΠΌ ΡΠΎΠ»ΡΠΊΠΎ ΠΏΠΎΠ»Π΅ title
curl -XGET "$ES_URL/blog/post/1?_source=title&pretty"{
"_index" : "blog",
"_type" : "post",
"_id" : "1",
"_version" : 1,
"found" : true,
"_source" : {
"title" : "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΠΊΠΎΡΡΡΠ°"
}
}Ake sikhombe amanye amaposi ambalwa futhi siqhube imibuzo eyinkimbinkimbi.
curl -XPUT "$ES_URL/blog/post/2" -d'
{
"title": "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΡΠ΅Π½ΠΊΠΈ",
"content": "<p>Π‘ΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ ΡΠ΅Π½ΠΊΠΎΠ²<p>",
"tags": [
"ΡΠ΅Π½ΠΊΠΈ",
"ΡΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ"
],
"published_at": "2014-08-12T20:44:42+00:00"
}'curl -XPUT "$ES_URL/blog/post/3" -d'
{
"title": "ΠΠ°ΠΊ Ρ ΠΌΠ΅Π½Ρ ΠΏΠΎΡΠ²ΠΈΠ»ΡΡ ΠΊΠΎΡΠ΅Π½ΠΎΠΊ",
"content": "<p>ΠΡΡΠ΅ΡΠ°Π·Π΄ΠΈΡΠ°ΡΡΠ°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ Π±Π΅Π΄Π½ΠΎΠ³ΠΎ ΠΊΠΎΡΠ΅Π½ΠΊΠ° Ρ ΡΠ»ΠΈΡΡ<p>",
"tags": [
"ΠΊΠΎΡΡΡΠ°"
],
"published_at": "2014-07-21T20:44:42+00:00"
}'Ukuhlunga
# Π½Π°ΠΉΠ΄Π΅ΠΌ ΠΏΠΎΡΠ»Π΅Π΄Π½ΠΈΠΉ ΠΏΠΎΡΡ ΠΏΠΎ Π΄Π°ΡΠ΅ ΠΏΡΠ±Π»ΠΈΠΊΠ°ΡΠΈΠΈ ΠΈ ΠΈΠ·Π²Π»Π΅ΡΠ΅ΠΌ ΠΏΠΎΠ»Ρ title ΠΈ published_at
curl -XGET "$ES_URL/blog/post/_search?pretty" -d'
{
"size": 1,
"_source": ["title", "published_at"],
"sort": [{"published_at": "desc"}]
}'{
"took" : 8,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 3,
"max_score" : null,
"hits" : [ {
"_index" : "blog",
"_type" : "post",
"_id" : "1",
"_score" : null,
"_source" : {
"title" : "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΠΊΠΎΡΡΡΠ°",
"published_at" : "2014-09-12T20:44:42+00:00"
},
"sort" : [ 1410554682000 ]
} ]
}
}Sikhethe okuthunyelwe kokugcina. size ikhawulela inani lamadokhumenti azokhishwa. total ibonisa isamba senani lamadokhumenti afana nesicelo. sort kokuphumayo kuqukethe izinombolo eziningi lapho ukuhlunga kwenziwa khona. Labo. idethi iguqulelwe ekubeni inombolo ephelele. Ulwazi olwengeziwe mayelana nokuhlunga lungatholakala ku .
Izihlungi nemibuzo
ES njengoba inguqulo 2 ingahlukanisi phakathi kwezihlungi nemibuzo, esikhundleni salokho .
Umongo wombuzo uyahluka engqikithini yesihlungi ngoba umbuzo ukhiqiza _score futhi awugciniwe. Ngizokukhombisa ukuthi yini _score kamuva.
Hlunga ngedethi
Sisebenzisa isicelo kumongo wesihlungi:
# ΠΏΠΎΠ»ΡΡΠΈΠΌ ΠΏΠΎΡΡΡ, ΠΎΠΏΡΠ±Π»ΠΈΠΊΠΎΠ²Π°Π½Π½ΡΠ΅ 1ΠΎΠ³ΠΎ ΡΠ΅Π½ΡΡΠ±ΡΡ ΠΈΠ»ΠΈ ΠΏΠΎΠ·ΠΆΠ΅
curl -XGET "$ES_URL/blog/post/_search?pretty" -d'
{
"filter": {
"range": {
"published_at": { "gte": "2014-09-01" }
}
}
}'Hlunga ngomaka
Sisebenzisa ukucinga ama-id edokhumenti aqukethe igama elinikeziwe:
# Π½Π°ΠΉΠ΄Π΅ΠΌ Π²ΡΠ΅ Π΄ΠΎΠΊΡΠΌΠ΅Π½ΡΡ, Π² ΠΏΠΎΠ»Π΅ tags ΠΊΠΎΡΠΎΡΡΡ
Π΅ΡΡΡ ΡΠ»Π΅ΠΌΠ΅Π½Ρ 'ΠΊΠΎΡΡΡΠ°'
curl -XGET "$ES_URL/blog/post/_search?pretty" -d'
{
"_source": [
"title",
"tags"
],
"filter": {
"term": {
"tags": "ΠΊΠΎΡΡΡΠ°"
}
}
}'{
"took" : 9,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 2,
"max_score" : 1.0,
"hits" : [ {
"_index" : "blog",
"_type" : "post",
"_id" : "1",
"_score" : 1.0,
"_source" : {
"title" : "ΠΠ΅ΡΠ΅Π»ΡΠ΅ ΠΊΠΎΡΡΡΠ°",
"tags" : [ "ΠΊΠΎΡΡΡΠ°", "ΡΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ" ]
}
}, {
"_index" : "blog",
"_type" : "post",
"_id" : "3",
"_score" : 1.0,
"_source" : {
"title" : "ΠΠ°ΠΊ Ρ ΠΌΠ΅Π½Ρ ΠΏΠΎΡΠ²ΠΈΠ»ΡΡ ΠΊΠΎΡΠ΅Π½ΠΎΠΊ",
"tags" : [ "ΠΊΠΎΡΡΡΠ°" ]
}
} ]
}
}Ukusesha umbhalo ogcwele
Amadokhumenti ethu amathathu aqukethe okulandelayo emkhakheni wokuqukethwe:
<p>Π‘ΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ ΠΊΠΎΡΡΡ<p><p>Π‘ΠΌΠ΅ΡΠ½Π°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ ΡΠ΅Π½ΠΊΠΎΠ²<p><p>ΠΡΡΠ΅ΡΠ°Π·Π΄ΠΈΡΠ°ΡΡΠ°Ρ ΠΈΡΡΠΎΡΠΈΡ ΠΏΡΠΎ Π±Π΅Π΄Π½ΠΎΠ³ΠΎ ΠΊΠΎΡΠ΅Π½ΠΊΠ° Ρ ΡΠ»ΠΈΡΡ<p>
Sisebenzisa ukucinga ama-id edokhumenti aqukethe igama elinikeziwe:
# source: false ΠΎΠ·Π½Π°ΡΠ°Π΅Ρ, ΡΡΠΎ Π½Π΅ Π½ΡΠΆΠ½ΠΎ ΠΈΠ·Π²Π»Π΅ΠΊΠ°ΡΡ _source Π½Π°ΠΉΠ΄Π΅Π½Π½ΡΡ
Π΄ΠΎΠΊΡΠΌΠ΅Π½ΡΠΎΠ²
curl -XGET "$ES_URL/blog/post/_search?pretty" -d'
{
"_source": false,
"query": {
"match": {
"content": "ΠΈΡΡΠΎΡΠΈΡ"
}
}
}'{
"took" : 13,
"timed_out" : false,
"_shards" : {
"total" : 5,
"successful" : 5,
"failed" : 0
},
"hits" : {
"total" : 3,
"max_score" : 0.11506981,
"hits" : [ {
"_index" : "blog",
"_type" : "post",
"_id" : "2",
"_score" : 0.11506981
}, {
"_index" : "blog",
"_type" : "post",
"_id" : "1",
"_score" : 0.11506981
}, {
"_index" : "blog",
"_type" : "post",
"_id" : "3",
"_score" : 0.095891505
} ]
}
}Kodwa-ke, uma sifuna "izindaba" emkhakheni wokuqukethwe, ngeke sithole lutho, ngoba Inkomba iqukethe amagama okuqala kuphela, hhayi iziqu zawo. Ukuze wenze usesho lwekhwalithi ephezulu, udinga ukulungisa i-analyzer.
Insimu _score imibukiso . Uma isicelo senziwe ngomongo wokuhlunga, khona-ke inani elithi _score liyohlala lilingana no-1, okusho ukufana okuphelele nesihlungi.
Abahlaziyi
ziyadingeka ukuguqula umbhalo womthombo ube isethi yamathokheni.
Abahlaziyi bahlanganisa eyodwa futhi eziningana ozikhethela . I-Tokenizer ingase yandulwe ngabaningana . Amathokheni aphula iyunithi yezinhlamvu yomthombo ibe amathokheni, njengezikhala nezinhlamvu zezimpawu zokuloba. I-TokenFilter ingashintsha amathokheni, isuse noma yengeze amasha, isibonelo, ishiye isiqu segama kuphela, isuse izakhi, yengeze amagama afanayo. I-CharFilter - ishintsha yonke iyunithi yezinhlamvu yomthombo, isibonelo, isika amathegi e-html.
I-ES inezimbalwa . Isibonelo, i-analyzer .
Asisebenzise ithuba futhi ake sibone ukuthi abahlaziyi abajwayelekile nabama-russian baluguqula kanjani uchungechunge "Izindaba ezihlekisayo mayelana namakati":
# ΠΈΡΠΏΠΎΠ»ΡΠ·ΡΠ΅ΠΌ Π°Π½Π°Π»ΠΈΠ·Π°ΡΠΎΡ standard
# ΠΎΠ±ΡΠ·Π°ΡΠ΅Π»ΡΠ½ΠΎ Π½ΡΠΆΠ½ΠΎ ΠΏΠ΅ΡΠ΅ΠΊΠΎΠ΄ΠΈΡΠΎΠ²Π°ΡΡ Π½Π΅ ASCII ΡΠΈΠΌΠ²ΠΎΠ»Ρ
curl -XGET "$ES_URL/_analyze?pretty&analyzer=standard&text=%D0%92%D0%B5%D1%81%D0%B5%D0%BB%D1%8B%D0%B5%20%D0%B8%D1%81%D1%82%D0%BE%D1%80%D0%B8%D0%B8%20%D0%BF%D1%80%D0%BE%20%D0%BA%D0%BE%D1%82%D1%8F%D1%82"{
"tokens" : [ {
"token" : "Π²Π΅ΡΠ΅Π»ΡΠ΅",
"start_offset" : 0,
"end_offset" : 7,
"type" : "<ALPHANUM>",
"position" : 0
}, {
"token" : "ΠΈΡΡΠΎΡΠΈΠΈ",
"start_offset" : 8,
"end_offset" : 15,
"type" : "<ALPHANUM>",
"position" : 1
}, {
"token" : "ΠΏΡΠΎ",
"start_offset" : 16,
"end_offset" : 19,
"type" : "<ALPHANUM>",
"position" : 2
}, {
"token" : "ΠΊΠΎΡΡΡ",
"start_offset" : 20,
"end_offset" : 25,
"type" : "<ALPHANUM>",
"position" : 3
} ]
}# ΠΈΡΠΏΠΎΠ»ΡΠ·ΡΠ΅ΠΌ Π°Π½Π°Π»ΠΈΠ·Π°ΡΠΎΡ russian
curl -XGET "$ES_URL/_analyze?pretty&analyzer=russian&text=%D0%92%D0%B5%D1%81%D0%B5%D0%BB%D1%8B%D0%B5%20%D0%B8%D1%81%D1%82%D0%BE%D1%80%D0%B8%D0%B8%20%D0%BF%D1%80%D0%BE%20%D0%BA%D0%BE%D1%82%D1%8F%D1%82"{
"tokens" : [ {
"token" : "Π²Π΅ΡΠ΅Π»",
"start_offset" : 0,
"end_offset" : 7,
"type" : "<ALPHANUM>",
"position" : 0
}, {
"token" : "ΠΈΡΡΠΎΡ",
"start_offset" : 8,
"end_offset" : 15,
"type" : "<ALPHANUM>",
"position" : 1
}, {
"token" : "ΠΊΠΎΡ",
"start_offset" : 20,
"end_offset" : 25,
"type" : "<ALPHANUM>",
"position" : 3
} ]
}I-analyzer evamile yahlukanisa intambo yaba izikhala futhi yaguqula yonke into yaba yizinhlamvu ezincane, umhlaziyi wesiRashiya wasusa amagama angabalulekile, wayiguqulela ekubeni yizinhlamvu ezincane futhi washiya isiqu samagama.
Ake sibone ukuthi iyiphi i-Tokenizer, TokenFilters, CharFilters esetshenziswa umhlaziyi waseRussia:
{
"filter": {
"russian_stop": {
"type": "stop",
"stopwords": "_russian_"
},
"russian_keywords": {
"type": "keyword_marker",
"keywords": []
},
"russian_stemmer": {
"type": "stemmer",
"language": "russian"
}
},
"analyzer": {
"russian": {
"tokenizer": "standard",
/* TokenFilters */
"filter": [
"lowercase",
"russian_stop",
"russian_keywords",
"russian_stemmer"
]
/* CharFilters ΠΎΡΡΡΡΡΡΠ²ΡΡΡ */
}
}
}Ake sichaze umhlaziyi wethu ngokusekelwe kusiRashiya, ozosika amathegi e-html. Masiyibize ngokuzenzakalelayo, ngoba isihlaziyi esinaleli gama sizosetshenziswa ngokuzenzakalelayo.
{
"filter": {
"ru_stop": {
"type": "stop",
"stopwords": "_russian_"
},
"ru_stemmer": {
"type": "stemmer",
"language": "russian"
}
},
"analyzer": {
"default": {
/* Π΄ΠΎΠ±Π°Π²Π»ΡΠ΅ΠΌ ΡΠ΄Π°Π»Π΅Π½ΠΈΠ΅ html ΡΠ΅Π³ΠΎΠ² */
"char_filter": ["html_strip"],
"tokenizer": "standard",
"filter": [
"lowercase",
"ru_stop",
"ru_stemmer"
]
}
}
}Okokuqala, wonke amathegi e-HTML azosuswa emgqeni womthombo, khona-ke izinga le-tokenizer lizolihlukanisa libe amathokheni, amathokheni avelayo azothuthela esimweni esincane, amagama angabalulekile azosuswa, futhi amathokheni asele azohlala isiqu segama.
Ukudala inkomba
Ngenhla sichaze i-analyzer ezenzakalelayo. Izosebenza kuzo zonke izinkambu zeyunithi yezinhlamvu. Okuthunyelwe kwethu kuqukethe inqwaba yomaka, ngakho omaka bazophinde bacutshungulwe ngumhlaziyi. Ngoba Sifuna okuthunyelwe ngokufana ncamashi nethegi, bese sidinga ukukhubaza ukuhlaziya inkambu yomaka.
Masidale i-blog2 yenkomba ene-analyzer kanye nemephu, lapho ukuhlaziywa kwenkambu yomaka kukhutshaziwe:
curl -XPOST "$ES_URL/blog2" -d'
{
"settings": {
"analysis": {
"filter": {
"ru_stop": {
"type": "stop",
"stopwords": "_russian_"
},
"ru_stemmer": {
"type": "stemmer",
"language": "russian"
}
},
"analyzer": {
"default": {
"char_filter": [
"html_strip"
],
"tokenizer": "standard",
"filter": [
"lowercase",
"ru_stop",
"ru_stemmer"
]
}
}
}
},
"mappings": {
"post": {
"properties": {
"content": {
"type": "string"
},
"published_at": {
"type": "date"
},
"tags": {
"type": "string",
"index": "not_analyzed"
},
"title": {
"type": "string"
}
}
}
}
}'Ake sengeze amaposi angu-3 afanayo kule nkomba (blog2). Ngizoyiyeka le nqubo ngoba... kufana nokwengeza amadokhumenti enkombeni yebhulogi.
Usesho lombhalo ogcwele ngokusekelwa kwenkulumo
Ake sibheke olunye uhlobo lwesicelo:
# Π½Π°ΠΉΠ΄Π΅ΠΌ Π΄ΠΎΠΊΡΠΌΠ΅Π½ΡΡ, Π² ΠΊΠΎΡΠΎΡΡΡ
Π²ΡΡΡΠ΅ΡΠ°Π΅ΡΡΡ ΡΠ»ΠΎΠ²ΠΎ 'ΠΈΡΡΠΎΡΠΈΠΈ'
# query -> simple_query_string -> query ΡΠΎΠ΄Π΅ΡΠΆΠΈΡ ΠΏΠΎΠΈΡΠΊΠΎΠ²ΡΠΉ Π·Π°ΠΏΡΠΎΡ
# ΠΏΠΎΠ»Π΅ title ΠΈΠΌΠ΅Π΅Ρ ΠΏΡΠΈΠΎΡΠΈΡΠ΅Ρ 3
# ΠΏΠΎΠ»Π΅ tags ΠΈΠΌΠ΅Π΅Ρ ΠΏΡΠΈΠΎΡΠΈΡΠ΅Ρ 2
# ΠΏΠΎΠ»Π΅ content ΠΈΠΌΠ΅Π΅Ρ ΠΏΡΠΈΠΎΡΠΈΡΠ΅Ρ 1
# ΠΏΡΠΈΠΎΡΠΈΡΠ΅Ρ ΠΈΡΠΏΠΎΠ»ΡΠ·ΡΠ΅ΡΡΡ ΠΏΡΠΈ ΡΠ°Π½ΠΆΠΈΡΠΎΠ²Π°Π½ΠΈΠΈ ΡΠ΅Π·ΡΠ»ΡΡΠ°ΡΠΎΠ²
curl -XPOST "$ES_URL/blog2/post/_search?pretty" -d'
{
"query": {
"simple_query_string": {
"query": "ΠΈΡΡΠΎΡΠΈΠΈ",
"fields": [
"title^3",
"tags^2",
"content"
]
}
}
}'Ngoba Sisebenzisa i-analyzer enesiqu sesi-Russian, bese lesi sicelo sizobuyisela wonke amadokhumenti, nakuba aqukethe kuphela igama elithi 'umlando'.
Isicelo singaqukatha izinhlamvu ezikhethekile, isibonelo:
""fried eggs" +(eggplant | potato) -frittata"Cela i-syntax:
+ signifies AND operation
| signifies OR operation
- negates a single token
" wraps a number of tokens to signify a phrase for searching
* at the end of a term signifies a prefix query
( and ) signify precedence
~N after a word signifies edit distance (fuzziness)
~N after a phrase signifies slop amount# Π½Π°ΠΉΠ΄Π΅ΠΌ Π΄ΠΎΠΊΡΠΌΠ΅Π½ΡΡ Π±Π΅Π· ΡΠ»ΠΎΠ²Π° 'ΡΠ΅Π½ΠΊΠΈ'
curl -XPOST "$ES_URL/blog2/post/_search?pretty" -d'
{
"query": {
"simple_query_string": {
"query": "-ΡΠ΅Π½ΠΊΠΈ",
"fields": [
"title^3",
"tags^2",
"content"
]
}
}
}'
# ΠΏΠΎΠ»ΡΡΠΈΠΌ 2 ΠΏΠΎΡΡΠ° ΠΏΡΠΎ ΠΊΠΎΡΠΈΠΊΠΎΠ²izithenjwa
PS
Uma unentshisekelo kulezo zifundo-zezihloko, unemibono yezihloko ezintsha noma uneziphakamiso zokubambisana, ngizojabula ukuthola umlayezo kumlayezo womuntu siqu noma nge-imeyili m.kuzmin+habr@darkleaf.ru.
Source: www.habr.com
