ELK学习总结(3-1)elk的基本查询
基本查询:内置条件
组合查询:组合基本查询
过滤:查询同时,通过filter筛选数据
准备工作
GET /library/books/_mget
{
"ids":["1","2","3","4","5","6"]
}
GET /library/_mapping
0、简单的查询
请求信息
GET /library/books/_search?q=title:elasticsearch
GET /library/_search?q=title:mongodb
GET /_search?q=title:blacksmith
1、term、terms查询:查询包含关键词
功能描述:term查询,查询某个字段例有某个关键词的文档
请求消息:
GET /library/books/_search
{
"query":{
"term":{
"preview":"elasticsearch"
}
}
}
功能描述:terms查询,查询某个字段例有多个关键词的文档,minimum_match(1,至少有一个关键词存在)
请求消息:
GET /library/books/_search
{
"query":{
"terms":{
"preview":["elasticsearch","book"],
"minimun_match":1
}
}
}
2、from、size: 控制查询返回的数量
请求信息
GET /library/books/_search?q=title:elasticsearch
GET /library/books/_search
{
"from":1,
"size":2,
"query":{
"term":{
"title":"elasticsearch"
}
}
}
3、返回版本号_version
请求信息
GET /library/books/_search
{
"version":true,
"query":{
"term":{
"preview":"elasticsearch"
}
}
}
4、match查询: 和term查询区别,会使用分析器
请求信息
GET /library/books/_search
{
"from":1,
"size":2,
"query":{
"term":{
"title":"elasticsearch"
}
}
}
3、返回版本号_version
请求信息
GET /library/books/_search
{
"version":true,
"query":{
"match":{
"preview":"elasticsearch"
}
}
}
GET /library/books/_search
{
"version":true,
"query":{
"match":{
"price":11
}
}
}
match_all 查询指定索引下的所有文档?
GET /library/books/_search
{
"query":{
"match_all":{}
}
}
match_phrase: 短语查询,slop定义关键词之间间隔多少位置单词
GET /library/books/_search
{
"query":{
"match_phrase":{
"preview":{
"query":"elasticsearch,distributed",
"slop":2
}
}
}
}
multi_match:可以查询指定多个字段都包含某个关键字的文档
GET /library/books/_search
{
"query":{
"multi_match":{
"query":"elasticsearch",
"fields":["title","preview"]
}
}
}
指定返回的字段
只能返回store为yes的字段
GET /library/books/search
{
"fields":["title","preview"],
"query":{
"match":{
"preview":"elasticsearch"
}
}
}
控制加载的字段:
GET /library/books/search
{
"partial_fields":{
"partial":{
"include":["preview"],
"exclude":["title","price"]
}
},
"query":{
"match":{
"preview":"elasticsearch"
}
}
}
5、排序查询: sort、asc/desc
请求信息
GET /library/books/_search
{
"query":{
"match_all":{}
},
"sort":[
{
"price":{
"order":"desc"
}
}
]
}
响应信息
6、prefix前缀匹配查询
请求信息
GET /library/books/_search
{
"query":{
"prefix":{
"title":{
"value":"ret"
}
}
}
}
响应信息
7、range范围查询(range,from,to,include_lower,include_upper,boost)
include_lower:包含范围左边界,默认是true
include_upper:包含范围右边界,默认是true
请求信息
GET /library/books/_search
{
"query":{
"range":{
"publish_date":{
"from":"2015-01-01",
"to":"2015-07-01"
}
}
}
}
GET /library/books/_search
{
"query":{
"range":{
"price":{
"from":"10.00",
"to":"20.00",
"include_lower":true,
"include_upper":true
}
}
}
}
响应信息
8、wildcard查询--很影响性能
* 代表1-n个字符
? 代表一个字符
请求信息
GET /library/books/_search
{
"query":{
"wildcard":{
"preview":“luc?ne”
}
}
}
响应信息
9、fuzzy模糊查询--很耗性能
value
boost
min_similarity
prefix_length
max_expansions
请求信息
GET /library/books/_search
{
"query":{
"fuzzy":{
"preview":“rabbit”,
"min_similarity":0.5
}
}
}
fuzzy_like_this
fuzzy_like_this_field
响应信息
10、more_like_this&more_like_this_field查询
fields:
like_text
percent_terms_to_match
min_term_freq
stop_words
min_doc_freq
min_word_len
max_word_len
boost_terms
boost
analyer
ELK学习总结(3-1)elk的基本查询的更多相关文章
- ELK学习实验013:ELK的一个完整的配置操作
前面做了关于ELK组件的各个实验,但是并没有真正的把各个组件结合起来做一个实验,现在使用一个脚本简单的生成日志,模拟生产不断产生日志的效果 一 流程说明 使用脚本产生日志,模拟用户的操作 日志的格式 ...
- ELK学习实验020:ELK使用kafka缓存
首先安装一个kafka集群,但是zookeeper使用单节点,可以让kafka快速跑起来,后续再研究kafka和zokkeeper的集群 1 安装Kafka集群 下面是三个节点都要做 [root@no ...
- ELK学习实验019:ELK使用redis缓存
1 安装一个redis服务 [root@node4 ~]# yum -y install redis 直接启动 [root@node4 ~]# systemctl restart redis [roo ...
- ELK学习链接
1. ELK原理与介绍 2. ELK部署记录
- ADO学习笔记之注入漏洞与参数化查询
ADO学习笔记之注入漏洞与参数化查询 作为新手,在学习ADO程序时,使用 sql 语言查询数据时,很容易写类似如下代码: using (SqlConnection con = new SqlConne ...
- 五、Django学习之基于对象的跨表查询
五.Django学习之基于对象的跨表查询 正向与反向查询 关键在于ForeignKey字段写的位置.例如下面这段代码, 关系属性(字段)写在哪个类(表)里面,从当前类(表)的数据去查询它关联类(表)的 ...
- ELK学习笔记(一)安装Elasticsearch、Kibana、Logstash和X-Pack
最近在学习ELK的时候踩了不少的坑,特此写个笔记记录下学习过程. 日志主要包括系统日志.应用程序日志和安全日志.系统运维和开发人员可以通过日志了解服务器软硬件信息.检查配置过程中的错误及错误发生的原因 ...
- ELK学习笔记之CentOS 7下ELK(6.2.4)++LogStash+Filebeat+Log4j日志集成环境搭建
0x00 简介 现在的公司由于绝大部分项目都采用分布式架构,很早就采用ELK了,只不过最近因为额外的工作需要,仔细的研究了分布式系统中,怎么样的日志规范和架构才是合理和能够有效提高问题排查效率的. 经 ...
- ELK学习之Logstash篇
Logstash在ELK这一整套解决方案中作为数据采集终端,支持对接Kafka.数据库(MySQL.Oracle).文件等等. 而在Logstash内部的数据流转,主要经过三个环节:input -&g ...
- ELK学习笔记(二)-HelloWorld实例+Kibana介绍
这次我们通过一个最简单的HelloWolrd来了解一下ELK的使用. 进入logstash的config目录,创建stdin.conf 文件. input{ stdin{ } } output{ st ...
随机推荐
- js命名中的关键字整理
- 直播-rtmp学习
RTMP(实时消息传输协议),官方介绍如下: Adobe’s Real Time Messaging Protocol (RTMP), an application-level protocol de ...
- windows中安装redis
Redis是有名的NoSql数据库,一般Linux都会默认支持.但在Windows环境中, Windows的Redis安装包需要到以下GitHub链接找到.链接:https://github.com/ ...
- Spring Boot 系列(八)@ControllerAdvice 拦截异常并统一处理
在spring 3.2中,新增了@ControllerAdvice 注解,可以用于定义@ExceptionHandler.@InitBinder.@ModelAttribute,并应用到所有@Requ ...
- MSIL实用指南-创建方法和定义参数
本篇讲解实现创建方法.指定参数的名称.实现参数加out和ref修饰符.以及参数加默认值. 创建方法 创建方法用类TypeAttributes的 DefineMethod(string name, Me ...
- delphi JPG图片 旋转 切边 缩放
unit UCutFigure_JPG; //JPG 切图 interface uses Windows, Messages, SysUtils, Variants, Classes, Graphic ...
- Laravel框架中的make方法详解
为什么网上已经有这么多的介绍Laravel的执行流程了,Laravel的容器详解了,Laravel的特性了,Laravel的启动过程了之类的文章,我还要来再分享呢? 因为,每个人的思维方式和方向是不一 ...
- AngularJs踩过的坑
1. 使用checkbox和radio时, 不能使用ng-model直接绑定原始对象, 需要绑定一个对象的某个子属性, 才能把值绑定到scope <label><input type ...
- Vue:渲染、指令、事件、组件、Props、Slots
如果要我用一句话描述使用 Vue 的经历,我可能会说“它如此合乎常理”或者“它提供给我需要的工具,而且没有妨碍我的工作”.每当学习 Vue 的时候,我都很高兴,因为很有意义,而且很优雅. 以上是我对 ...
- 基于keras的BiLstm与CRF实现命名实体标注
众所周知,通过Bilstm已经可以实现分词或命名实体标注了,同样地单独的CRF也可以很好的实现.既然LSTM都已经可以预测了,为啥要搞一个LSTM+CRF的hybrid model? 因为单独LSTM ...