Elasticsearch5.5.1学习笔记
在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学习笔记的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
- JAVA GUI编程学习笔记目录
2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- CSS学习笔记
CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...
- HTML学习笔记
HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...
- DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记
今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...
随机推荐
- listview控件的使用
listview控件是用于实现向上下两个方向翻动的界面(类似于QQ音乐查找歌手时的哪个界面),但是listview只是提供了一个空架子并没有什么实质的东西,那么这些东西要从哪里获得呢,那就要用到适配器 ...
- 2018年天梯赛LV2题目汇总小结
Ⅰ.L2-1 分而治之---邻接表 分而治之,各个击破是兵家常用的策略之一.在战争中,我们希望首先攻下敌方的部分城市,使其剩余的城市变成孤立无援,然后再分头各个击破.为此参谋部提供了若干打击方案.本题 ...
- 【C++】回看面向对象与C++
本文将记录在C++与面向对象的重新学习过程中的要点: 未定义行为
- VR外包团队—国内首家VR虚拟现实主题公园即将在北京推出
期,美国“The VOID”.澳洲“Zero Latency”两大虚拟现实主题乐园让许多爱好者兴奋至极,门票据说都已经预约到明年2月!在如此巨大的商机面前,谁将抢到国内VR虚拟现实主题公园第一块蛋糕? ...
- svg(一)
<svg width="100%" height="100%" version="1.1" xmlns="http://ww ...
- [数据结构]P1.1 链表结构
* 注: 本文/本系列谢绝转载,如有转载,本人有权利追究相应责任. 2019年4月8日 Stan Zhang 2019年4月8日 格物致知,经世致用. [面试题]1.为什么要用链表? 数组具有的缺陷 ...
- LeetCode--025--k个一组翻转链表(java)
给出一个链表,每 k 个节点一组进行翻转,并返回翻转后的链表. k 是一个正整数,它的值小于或等于链表的长度.如果节点总数不是 k 的整数倍,那么将最后剩余节点保持原有顺序. 示例 : 给定这个链表: ...
- 关于Djanggo的环境变量
templates是Django指定的T目录,pycharm下templates的图标会变亮,static则可以改动.下面STATIC_URL可以指定,STATICFILES_DIRS则指定了temp ...
- css实现响应式布局的相关内容
所以我就在做自适应的时候查了一些资料 首先我发现一个问题:有响应式布局和自适应布局两种布局效果 简单来说,响应式布局就是不同的设备无论大小 布局都自动调整大小 页面布局都一样 可以保证无论什么设备 用 ...
- Highcharts 时间格式化函数
1.函数构造: Highcharts.dateFormat(String format, [Number time], [Boolean capitalize]) 2.参数列表: Strin ...