中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

elasticsearch中文分詞集成怎么實現

發布時間:2021-12-16 10:15:13 來源:億速云 閱讀:157 作者:iii 欄目:云計算

本篇內容介紹了“elasticsearch中文分詞集成怎么實現”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

對于索引可能最關系的就是分詞了 一般對于es 來說默認的smartcn  但效果不是很好 

一個是ik的,一個是mmseg的,下面分別介紹下兩者的用法,其實都差不多的,先安裝插件,命令行:

安裝ik插件

plugin -install medcl/elasticsearch-analysis-ik/1.1.0

下載ik相關配置詞典文件到config目錄

elasticsearch中文分詞集成怎么實現

unzip ik.zip

rm ik.zip

分詞配置

ik分詞配置,在elasticsearch.yml文件中加上

index:
  analysis:                   
    analyzer:      
      ik:
          alias: [ik_analyzer]
          type: org.elasticsearch.index.analysis.IkAnalyzerProvider

index.analysis.analyzer.ik.type : “ik”

安裝mmseg插件:

bin/plugin -install medcl/elasticsearch-analysis-mmseg/1.1.0

下載相關配置詞典文件到config目錄

cd config

wget http://github.com/downloads/medcl/elasticsearch-analysis-mmseg/mmseg.zip --no-check-certificate

unzip mmseg.zip

rm mmseg.zip

mmseg分詞配置,也是在在elasticsearch.yml文件中

index:
  analysis:
    analyzer:
      mmseg:
          alias: [news_analyzer, mmseg_analyzer]
          type: org.elasticsearch.index.analysis.MMsegAnalyzerProvider

index.analysis.analyzer.default.type : "mmseg"

mmseg分詞還有些更加個性化的參數設置如下

index:
  analysis:
    tokenizer:
      mmseg_maxword:
          type: mmseg
          seg_type: "max_word"
      mmseg_complex:
          type: mmseg
          seg_type: "complex"
      mmseg_simple:
          type: mmseg
          seg_type: "simple"

這樣配置完后插件安裝完成,啟動es就會加載插件。

定義mapping

在添加索引的mapping時就可以這樣定義分詞器

{
   "page":{
      "properties":{
         "title":{
            "type":"string",
            "indexAnalyzer":"ik",
            "searchAnalyzer":"ik"
         },
         "content":{
            "type":"string",
            "indexAnalyzer":"ik",
            "searchAnalyzer":"ik"
         }
      }
   }
}

indexAnalyzer為索引時使用的分詞器,searchAnalyzer為搜索時使用的分詞器。

java mapping代碼如下:

XContentBuilder content = XContentFactory.jsonBuilder().startObject()
        .startObject("page")
          .startObject("properties")       
            .startObject("title")
              .field("type", "string")           
              .field("indexAnalyzer", "ik")
              .field("searchAnalyzer", "ik")
            .endObject() 
            .startObject("code")
              .field("type", "string")         
              .field("indexAnalyzer", "ik")
              .field("searchAnalyzer", "ik")
            .endObject()     
          .endObject()
         .endObject()
       .endObject()

測試分詞可用調用下面api,注意indexname為索引名,隨便指定一個索引就行了

“elasticsearch中文分詞集成怎么實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

湘潭县| 贺兰县| 襄垣县| 祁阳县| 凤翔县| 嘉禾县| 临湘市| 石景山区| 公主岭市| 东方市| 淮南市| 柯坪县| 徐闻县| 渭南市| 三门峡市| 彩票| 枣庄市| 湄潭县| 若羌县| 巴马| 新龙县| 宽城| 鲁甸县| 射洪县| 宁陕县| 青河县| 潼南县| 驻马店市| 南靖县| 池州市| 原平市| 辽中县| 葵青区| 红安县| 大城县| 二手房| 名山县| 汉阴县| 汉沽区| 苏州市| 黄石市|