ElasticSearch自定義排序(轉(zhuǎn)載)

轉(zhuǎn)自:http://www.dcharm.com/?p=469

本文討論ES的自定義排序的兩種實(shí)現(xiàn)形式:基于groovy腳本的自定義排序和基于native script的自定義排序。

1. 基于Groovy腳本的自定義排序

ES的排序腳本必須放在config/scripts下面,ES能夠自動(dòng)發(fā)現(xiàn)這些腳本并提供對(duì)外使用奖蔓, 例如編寫腳本calculate-score.groovy

log(_score*2)+my_modifier

腳本中my_modifier是搜索請(qǐng)求中的參數(shù),_score是ES計(jì)算得到的文檔分?jǐn)?shù)。發(fā)起搜索請(qǐng)求時(shí)指定用calculate-score排序

curl -XPOST localhost:9200/_search -d '{

"query": {

"function_score": {

"query": {

"match": {

"body": "foo"

}

},

"functions": [

{

"script_score": {

"lang": "groovy",

"script_file": "calculate-score",

"params": {

"my_modifier": 8

}

}

}

]

}

}}'

在上面的請(qǐng)求指定了my_modifier的值為8,排序時(shí)calculate-score腳本中對(duì)應(yīng)變量my_modifier就會(huì)被賦值為8光督。除此以外苛茂,還可以在腳本中通過doc[‘field_name’].value或者doc[‘field_name’].value獲取field data中的字段或油;通過_fields[‘field_name’]獲取沒有存放在doc values中但是放在了ES存儲(chǔ)(store)中的字段。需要注意的是doc values會(huì)被載入到內(nèi)存交胚,而store不會(huì),所以doc values取值速度更快盈电。

ES會(huì)周期性的掃描config/scripts下面的文件蝴簇,新增和被修改的腳本會(huì)被重新載入,并從script緩存中刪除文件夾中被刪除的腳本匆帚。重載的頻率可以在watcher.interval中說明熬词,默認(rèn)是60s。如果要禁止重載腳本吸重,可以設(shè)置script.auto_reload_enabled為false互拾。

2. 基于native腳本的自定義排序

ES中的native腳本使用java語言編寫,并需要實(shí)現(xiàn)相應(yīng)的NativeScriptFactory接口嚎幸。

public class CustomScriptFactory implements NativeScriptFactory {

@Override

publicExecutableScript newScript(@NullableMap params) {

returnnewCustomScript(params);

}

}

public class CustomScript extends AbstractDoubleSearchScript {

private double myVal;

private double base;

public CustomScript(@NullableMap params){

base = (Double)params.get("myVal");

}

@Override

public double runAsDouble() {

doublea = ((ScriptDocValues.Longs)doc().get("itemNum")).getValue();

returna +2;

}

}

將打包后的jar包放到ES的class path中颜矿,并在配置文件config/elasticsearch.yml中增加一行配置:

script.native.mynativescript.type: com.ymatou.search.searcher.script.CustomScriptFactory

Native腳本不能被ES自動(dòng)發(fā)現(xiàn),需要重啟ES嫉晶,另外搜索請(qǐng)求的格式也有些不同骑疆。

curl -XPOST localhost:19200/m2c/item/_search -d '{

"query": {

"function_score": {

"query": {

"match_all": {}

},

"functions": [

{

"script_score": {

"lang":"native",

"script":"m2c_jyh_base",

"params": {

"myVal": 10.0

}

}

}

]

}

}

}'

3. Groovy腳本自定義排序和Native自定排序的比較

相對(duì)于Native自定義排序,Groovy腳本自定義排序?qū)崿F(xiàn)和部署方便:不用編譯打包替废,不用修改配置文件箍铭,也不用重啟ES,但是Native自定義排序的速度是Groovy腳本自定義排序速度的1到3倍椎镣,因此建議大家使用Groovy腳本做實(shí)驗(yàn)诈火,但是在生產(chǎn)環(huán)境中使用Native腳本。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末衣陶,一起剝皮案震驚了整個(gè)濱河市柄瑰,隨后出現(xiàn)的幾起案子闸氮,更是在濱河造成了極大的恐慌,老刑警劉巖教沾,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蒲跨,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡授翻,警方通過查閱死者的電腦和手機(jī)或悲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來堪唐,“玉大人巡语,你說我怎么就攤上這事』床ぃ” “怎么了男公?”我有些...
    開封第一講書人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)合陵。 經(jīng)常有香客問我枢赔,道長(zhǎng),這世上最難降的妖魔是什么拥知? 我笑而不...
    開封第一講書人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任踏拜,我火速辦了婚禮,結(jié)果婚禮上低剔,老公的妹妹穿的比我還像新娘速梗。我一直安慰自己,他們只是感情好襟齿,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開白布姻锁。 她就那樣靜靜地躺著,像睡著了一般蕊唐。 火紅的嫁衣襯著肌膚如雪屋摔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評(píng)論 1 301
  • 那天替梨,我揣著相機(jī)與錄音钓试,去河邊找鬼。 笑死副瀑,一個(gè)胖子當(dāng)著我的面吹牛弓熏,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播糠睡,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼挽鞠,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起信认,我...
    開封第一講書人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤材义,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后嫁赏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體其掂,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年潦蝇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了款熬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡攘乒,死狀恐怖贤牛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情则酝,我是刑警寧澤殉簸,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站堤魁,受9級(jí)特大地震影響喂链,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜妥泉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望洞坑。 院中可真熱鬧盲链,春花似錦、人聲如沸迟杂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)排拷。三九已至侧漓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間监氢,已是汗流浹背布蔗。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留浪腐,地道東北人纵揍。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像议街,于是被迫代替她去往敵國(guó)和親泽谨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,102評(píng)論 25 707
  • elastic search真是個(gè)讓人既愛又恨的東西,性能強(qiáng)勁吧雹,功能強(qiáng)大骨杂,但就是在使用中遇到種種問題(多半因?yàn)槲臋n...
    chenmingang閱讀 1,761評(píng)論 2 2
  • 記錄一下,elasticsearch/lucene關(guān)于文檔與query之間相關(guān)性的計(jì)算方式雄卷,目錄如下搓蚪, Lucen...
    chenfh5閱讀 4,730評(píng)論 1 7
  • 昨天有小A同學(xué)給我反饋了工作坊的感受,字里行間能感受到她因?yàn)橛謱?duì)自己有了進(jìn)一步的了解而快樂龙亲。但是有兩個(gè)想法我想和大...
    啟萌生涯閱讀 501評(píng)論 0 0
  • 這年頭兒,創(chuàng)業(yè)這詞不新鮮拂盯,沒畢業(yè)的大學(xué)生佑女,都可以拉幾個(gè)志同道合的湊一伙兒琢磨點(diǎn)發(fā)財(cái)?shù)拈T道,哦谈竿,不對(duì)团驱,圖什么錢啊,都...
    失心莫妮閱讀 711評(píng)論 0 2