在linux下增加ik分词

一、下载分词器安装包

wget https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v5.5.1/elasticsearch-analysis-ik-5.5.1.zip

二、解压并安装

1.移动elasticsearch-analysis-ik-5.5.1.zip到安装目录的plugins目录

mv elasticsearch-analysis-ik-5.5.1.zip /root/elasticsearch/elasticsearch-5.5.1/plugins/

2.进入安装目录的plugins目录

cd /root/elasticsearch/elasticsearch-5.5.1/plugins/

3.解压

unzip elasticsearch-analysis-ik-5.5.1.zip

4.删除压缩包

rm -rf elasticsearch-analysis-ik-5.5.1.zip

按照官方说明,这时已经成功安装了,重启ElasticSearch即可。

三、测试

使用的是postman工具

扩展自己的分词:

my.dic

小米手机
华为手机

其他的查询语句:

集群健康

curl -X GET 'http://localhost:9200/_cluster/health?pretty=true'

Elasticsearch有一个功能叫做聚合(aggregations),它允许你在数据上生成复杂的分析统计。它很像SQL中的GROUP BY但是功能更强大。

megacorp/employee的格式:

 {
"first_name" : "John",
"last_name" : "Smith",
"age" : 25,
"about" : "I love to go rock climbing",
"interests" : [
"sports",
"music"
]
}

找到所有职员中最大的共同点(兴趣爱好)是什么:

{
"aggs": {
"all_interests": {
"terms": {
"field": "interests.keyword"
}
}
}
}

统计每种兴趣下职员的平均年龄:

curl -X GET 'http://localhost:9200/megacorp/employee/_search?pretty=true' -d '
{
"aggs" : {
"all_interests" : {
"terms" : { "field" : "interests.keyword" },
"aggs" : {
"avg_age" : {
"avg" : { "field" : "age" }
}
}
}
}
}’

合并多子句

{
"query": {
"bool": {
"must": {
"match": {
"first_name": "doublas"
}
},
"must_not": {
"match": {
"last_name": "roger"
}
}
}
}
}

查询语句里面加过滤条件:

{
"query": {
"bool": {
"filter": {
"term": {
"first_name": "john"
}
},
"must": {
"match": {
"last_name": "smith"
}
}
}
}
}

查询是高亮:

{
"query":{
"match":{
"about":"rock climbing"
}
},
"highlight":{
"pre_tags":["<font color='red'>"],
"post_tags":["</font>"],
"fields":{
"about":{}
}
}
}

multi_match查询

http://localhost:9200/megacorp/employee/_search?pretty=true

{
"query":{
"multi_match":{
"query":"smith",
"fields":["last_name","first_name"]
}
}
} 查询last_name,或first_name有smith的文档 也可以使用通配符 {
"query":{
"multi_match":{
"query":"smith",
"fields": "*_name"
}
}
}

对结果排序:

{
"query":{
"match":{
"last_name":"smith fir"
}
},
"sort":{
"age":"desc"
}
}

多级排序

{
"query":{
"match":{
"about":"I like to collect"
}
},
"sort":[
{"age":{"order":"desc"}},
{"_score":{"order":"desc"}}
]
}

实现分词动态加载:

ik分词的配置中是可以远程加载词库的,此时新建一个web项目代表远程词库,例如我的词库地址为:

配置:

当我们启动ES的时候会看到相应的日志记录,如下:

elasticsearch6.0.0 ik分词器 测试:

curl -H "Content-Type: application/json" -XGET 'http://localhost:9200/_analyze?pretty=true' -d '

> {
> "analyzer":"ik_max_word",
> "text":"中华人民共和国"
> }'

Elasticsearch5.5.1学习笔记的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  3. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  4. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  5. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  6. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  7. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  8. HTML学习笔记

    HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...

  9. DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记

    今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...

随机推荐

  1. FJUT3701 这也是一道数论题(线段树)题解

    Problem Description 好久没出数据结构题,现在赶紧来做道数据结构题热热身 小q现在要去银行,他有个很厉害的bug能看到前面排队的人.假如当前有人正在办理业务,那么肯定要等待前一个人完 ...

  2. QT 设置应用程序名称和主窗口标题

    1.设置应用程序名称 在工程文件.pro文件中,修改Target为想设置的名称 TARGET = MXEditer 2.设置主窗口标题,在main文件中,我的主窗口是MainWindow. int m ...

  3. _mount_vendor

    允许NPC售卖坐骑时进行预览

  4. Flex外包公司——案例汇总

    Flex做的案例汇总: http://flex.org/showcase/ http://taggraph.com/everybody http://demoprod.informationbuild ...

  5. 封装axios在vue-cli项目中便捷使用

    首先创建一个vue-cli搭建起来的vue项目这个不用多说了. 安装axios,使用npm install axios --save命令安装依赖,这时候项目的package.json文件中的" ...

  6. C# --- ??(空接合操作符)的一个案例

    Nullable<Int32> x = null; Nullable<Int32> y = null; Nullable<Int32> z = null; Int3 ...

  7. 亲自打造Deferred对象

    经过对比之后,决心学习jQuery,自己打造一个Deferred对象.var util = require('./util.js');function Callbacks() { var list = ...

  8. 『Python CoolBook:heapq』数据结构和算法_heapq堆队列算法&容器排序

    一.heapq堆队列算法模块 本模块实现了堆队列算法,也叫作优先级队列算法.堆队列是一棵二叉树,并且拥有这样特点,它的父节点的值小于等于任何它的子节点的值. 本模块实际上实现了一系列操作容器的方法,使 ...

  9. python_入门_三级菜单

    '''程序:三级菜单要求:1.打印省.市.县三级菜单2.可返回上一级3.可随时退出程序''' # -*- coding: utf-8 -*- # __author__ = 'qi' prov_city ...

  10. CSS中的盒子模型与 box-sizing 属性

    盒子模型是css中一个重要的概念,是开发网页必须要用的布局方法.盒子模型有两种,分别是标准 w3c 盒子模型和 ie 盒子模型. 标准 w3c 盒子模型:包括 magin(外边距).border(边框 ...