zoukankan      html  css  js  c++  java
  • ELK之es常用查询语句

      参考:https://www.cnblogs.com/kyleinjava/p/10497042.html

                https://blog.csdn.net/luanpeng825485697/article/details/83411704

      elasticsearch定义了两种查询方式

      一.索引(index),type,document相关语句

        1,列出所有索引状态

    GET /_cat/indices?v
    

         可以使用kibana的dev tools

    health status index                       uuid                   pri rep docs.count docs.deleted store.size pri.store.size
    yellow open   metricbeat-6.3.1-2019.09.30 AzJBakNPSP-OqcByGT9xOw   1   1      53244            0       10mb           10mb
    yellow open   watcher_alarms              AIc2q3VhTLedzu6ljScOjA   5   1          0            0      1.2kb          1.2kb
    yellow open   website                     Big3pMt4QTmx4rCii_7jqw   5   1          0            0      1.1kb          1.1kb
    yellow open   metricbeat-6.3.1-2019.09.29 Lv8UC-H7Q4GRShXvCKVwkg   1   1     135000            0     25.4mb         25.4mb
    yellow open   watcher_alarms-2019.09.27   kJOeaPQXRAOI17qB11eL-A   5   1       1033            0    383.6kb        383.6kb
    yellow open   watcher_alarms-2019.09.26   GAAJ8Uc1QvuoxjUWau6Dcg   5   1       1876            0    619.9kb        619.9kb
    green  open   .kibana                     3DFTWNpIQ4yMq3wYNmxfPw   1   0        130            2    292.4kb        292.4kb
    yellow open   watcher_alarms-2019.09.28   H4KySJ6lQqaKYb6r7-8TzA   5   1         43            0    593.6kb        593.6kb
    yellow open   system-log-2019.09          uCdgYBmASpCjxO9-DyGyOg   5   1      49005            0     42.7mb         42.7mb
    yellow open   watcher_alarms-2019.09.29   eYDS-TN4RLqOpY0D1OExEQ   5   1        133            0    319.9kb        319.9kb
    

       字段说明

    health:健康状态 red,yellow,green
    status:状态open
    index:索引名
    uuid:唯一标识符uuid
    pri:主分片数
    rep:副本数
    docs.count:总计多少条日志
    docs.deleted:删除记录
    store.size:存储该index文件的大小
    pri.store.size:主存储大小
    

         2,查询索引详细信息

    GET /index1,index2     查询索引index1和索引index2的基本信息
    GET /_all    查询所有的基本信息
    GET /s*    使用通配符来查询所有以s开头的索引信息
    

         3,创建索引

        setting中可以设置索引的的主分片数number_of_shards默认为5,和主分片的副本数number_of_replicas默认是1;

        mapping中主要设置各个type的映射关系

    PUT /my_index
    {
        "settings": {... any setting ...}
        "mappings": {
            "type_one": {... any mappings ...},
            "type_two":  {... any mappings ...},
            ...
        }      
    }
    

         创建一个索引gb

    PUT /gb
    {
      "mappings": {
        "tweet" : {
          "properties" : {
            "tweet" : {
              "type" :    "text",
              "analyzer": "english"
            },
            "date" : {
              "type" :   "date"
            },
            "name" : {
              "type" :   "text"
            },
            "user_id" : {
              "type" :   "long"
            }
          }
        }
      }
    }   
    

       创建成功提示

    {
      "acknowledged": true,
      "shards_acknowledged": true,
      "index": "index1"
    }
    

       查看刚创建的索引gb的详细信息

    GET /gb
    
    {
      "gb": {
        "aliases": {},
        "mappings": {
          "tweet": {
            "properties": {
              "date": {
                "type": "date"
              },
              "name": {
                "type": "text"
              },
              "tweet": {
                "type": "text",
                "analyzer": "english"
              },
              "user_id": {
                "type": "long"
              }
            }
          }
        },
        "settings": {
          "index": {
            "creation_date": "1569814449442",
            "number_of_shards": "5",
            "number_of_replicas": "1",
            "uuid": "841k18xLSHOOltY_1UKrSA",
            "version": {
              "created": "6020499"
            },
            "provided_name": "index1"
          }
        }
      }
    }
    

         4,删除索引

    DELETE /index1 #删除索引index1
    DELETE /_all #删除所有索引,慎用    
    DELETE /*
    

         5,在索引的映射中增加一个字段

    PUT /gb/_mapping/tweet
    {
      "properties": {
        "tag": {
          "type": "text",
          "index": false
        }
      }
    }
    

         运行成功返回

    {
      "acknowledged": true
    }
    

       增加字段之前的映射mapping信息

      使用命令 查看

    GET /gb/_mapping
    

       返回

    {
      "gb": {
        "mappings": {
          "tweet": {
            "properties": {
              "date": {
                "type": "date"
              },
              "name": {
                "type": "text"
              },
              "tweet": {
                "type": "text",
                "analyzer": "english"
              },
              "user_id": {
                "type": "long"
              }
            }
          }
        }
      }
    }
    

         添加成功以后查看

    {
      "gb": {
        "mappings": {
          "tweet": {
            "properties": {
              "date": {
                "type": "date"
              },
              "name": {
                "type": "text"
              },
              "tag": {
                "type": "text",
                "index": false
              },
              "tweet": {
                "type": "text",
                "analyzer": "english"
              },
              "user_id": {
                "type": "long"
              }
            }
          }
        }
      }
    }
    

     

         6,查看某个type的映射关系

    GET /{index}/_mapping/{type}
    
    GET /gb/_mapping/tweet
    ///返回
    {
      "gb": {
        "mappings": {
          "tweet": {
            "properties": {
              "date": {
                "type": "date"
              },
              "name": {
                "type": "text"
              },
              "tag": {
                "type": "text",
                "index": false
              },
              "tweet": {
                "type": "text",
                "analyzer": "english"
              },
              "user_id": {
                "type": "long"
              }
            }
          }
        }
      }
    }
    

        

        7,在索引文档中添加或者替换文档

        在添加的时候id并不是必须的,如果没有id则会随机产生一个id需要使用POST才能随机生成id

        往索引gb里面添加一条数据指定id为1

    PUT /gb/tweet/1
    {
      "username":"liuym",
      "user_id":16
    }
    

         返回

    {
      "_index": "gb",
      "_type": "tweet",
      "_id": "1",
      "_version": 1,
      "result": "created",
      "_shards": {
        "total": 2,
        "successful": 1,
        "failed": 0
      },
      "_seq_no": 0,
      "_primary_term": 1
    }
    

         搜索刚刚添加的数据

    GET /gb/_server
    

     

         也可以通过GET方式查询id查看

    GET /gb/tweet/1
    ///返回
    {
      "_index": "gb",
      "_type": "tweet",
      "_id": "1",
      "_version": 1,
      "found": true,
      "_source": {
        "username": "liuym",
        "user_id": 16
      }
    }
    

         也可以只查看_source中部分字段,例如只查看name

    GET /gb/tweet/1?_source=name
    

         8,更新索引文档中的内容

    PUT /{index}/{type}/{id}
    POST  /{index}/{type}/{id}/_update
    

          一种是使用PUT方法旧数据全部覆盖,使用新数据代替

    PUT /gb/tweet/1
    {
      "name":"zhangsan",
      "user_id":8
    }
    

         修改后内容

    {
      "_index": "gb",
      "_type": "tweet",
      "_id": "1",
      "_version": 6,
      "found": true,
      "_source": {
        "name": "zhangsan",
        "user_id": 9
      }
    }
    

         一种是通过POST方式,只对部分字段进行修改

    POST gb/tweet/1/_update
    {
     "doc":{
       "username": "zhansan"
     }
    }
    

         PS:注意最后加更新_update  内部需要加doc

        9,删除文档

    DELETE /{index}/{type}/{id}
    

         删除id为1的文档

    DELETE /gb/tweet/1
    

         返回

    {
      "_index": "gb",
      "_type": "tweet",
      "_id": "1",
      "_version": 14,
      "result": "deleted",
      "_shards": {
        "total": 2,
        "successful": 1,
        "failed": 0
      },
      "_seq_no": 14,
      "_primary_term": 1
    }
    

         查看没有数据了

    GET /gb/tweet/1
    

         返回

    {
      "_index": "gb",
      "_type": "tweet",
      "_id": "1",
      "found": false
    }
    

         found为false就是没有发现

        10,批处理

        批量添加

    POST /gb/tweet/_bulk
    {"index":{"_id":"1"}}
    {"name":"zhangsan"}
    {"index":{"_id":"2"}}
    {"name":"lisi"}
    

         返回

    {
      "took": 39,
      "errors": false,
      "items": [
        {
          "index": {
            "_index": "gb",
            "_type": "tweet",
            "_id": "1",
            "_version": 1,
            "result": "created",
            "_shards": {
              "total": 2,
              "successful": 1,
              "failed": 0
            },
            "_seq_no": 6,
            "_primary_term": 1,
            "status": 201
          }
        },
        {
          "index": {
            "_index": "gb",
            "_type": "tweet",
            "_id": "2",
            "_version": 1,
            "result": "created",
            "_shards": {
              "total": 2,
              "successful": 1,
              "failed": 0
            },
            "_seq_no": 4,
            "_primary_term": 1,
            "status": 201
          }
        }
      ]
    }
    

         查看

    GET /gb/_search
    

         返回

    {
      "took": 3,
      "timed_out": false,
      "_shards": {
        "total": 5,
        "successful": 5,
        "skipped": 0,
        "failed": 0
      },
      "hits": {
        "total": 2,
        "max_score": 1,
        "hits": [
          {
            "_index": "gb",
            "_type": "tweet",
            "_id": "2",
            "_score": 1,
            "_source": {
              "name": "lisi"
            }
          },
          {
            "_index": "gb",
            "_type": "tweet",
            "_id": "1",
            "_score": 1,
            "_source": {
              "name": "zhangsan"
            }
          }
        ]
      }
    }
    

         批量更新与删除

    POST /gb/tweet/_bulk
    {"update":{"_id":"1"}}
    {"doc":{"name":"wangwu"}}
    {"delete":{"_id":"2"} }
    

         修改_id为1的name字段,删除_id为2的数据

        返回

    {
      "took": 48,
      "errors": false,
      "items": [
        {
          "update": {
            "_index": "gb",
            "_type": "tweet",
            "_id": "1",
            "_version": 2,
            "result": "updated",
            "_shards": {
              "total": 2,
              "successful": 1,
              "failed": 0
            },
            "_seq_no": 7,
            "_primary_term": 1,
            "status": 200
          }
        },
        {
          "delete": {
            "_index": "gb",
            "_type": "tweet",
            "_id": "2",
            "_version": 2,
            "result": "deleted",
            "_shards": {
              "total": 2,
              "successful": 1,
              "failed": 0
            },
            "_seq_no": 5,
            "_primary_term": 1,
            "status": 200
          }
        }
      ]
    }
    

         查看是否修改成功

    GET /gb/tweet/_search
    

         返回

    {
      "took": 1,
      "timed_out": false,
      "_shards": {
        "total": 5,
        "successful": 5,
        "skipped": 0,
        "failed": 0
      },
      "hits": {
        "total": 1,
        "max_score": 1,
        "hits": [
          {
            "_index": "gb",
            "_type": "tweet",
            "_id": "1",
            "_score": 1,
            "_source": {
              "name": "wangwu"
            }
          }
        ]
      }
    }
    

         修改字段成功并且删除了_id为2的数据

        11,批量导入大量数据

     curl -H "Content-Type: application/json" -XPOST "localhost:9200/bank/account/_bulk?pretty&refresh" --data-binary "@accounts.json"
    

         12,查询文档数

    #查询所有文档数
    GET /_count
    

         返回

    {
      "count": 759185,
      "_shards": {
        "total": 61,
        "successful": 61,
        "skipped": 0,
        "failed": 0
      }
    }
    

         

    #查询索引gb中的文档数
    GET /gb/_count
    
    #查询某个type的文档数
    GET /gb/tweet/_count
    

       二,简单查询

        1,使用GET请求

    GET /gb/tweet/_search
    

         返回

    {
      "took": 2,    #查询执行时间单位是毫秒
      "timed_out": false, #查询是否超时
      "_shards": {  #表示查询参与的分片总数,以及这些分片成功了多少个失败了多少个
        "total": 5,
        "successful": 5,
        "skipped": 0,
        "failed": 0
      },
      "hits": {  #所有查询到的结果
        "total": 1, #匹配的文档总数
        "max_score": 1, #结果中最大评分
        "hits": [
          {
            "_index": "gb", #索引名称
            "_type": "tweet", #type名称
            "_id": "1",      #id名称
            "_score": 1,   #评分
            "_source": {   #存储的数据源信息
              "name": "wangwu"
            }
          }
        ]
      }
    }
    

         2,同时查询多索引多类型的数据

    GET /_search  #在所有索引中搜索所有的类型
    GET /gb/_search #在gb索引中搜索所有的类型
    GET /gb,us/_search #在 gb 和 us 索引中搜索所有的文档
    GET /g*,u*/_search #在任何以 g 或者 u 开头的索引中搜索所有的类型
    GET /gb/tweet/_search #在gb索引中搜索tweet类型
    GET /gb,us/user,tweet/_search在 gb 和 us 索引中搜索 user 和 tweet 类型
    GET /_all/user,tweet/_search在所有的索引中搜索 user 和 tweet 类型
    

         3,不查询文档的元数据,只查询source部分的数据

    GET /{index}/{type}/{id}/_source
    

         示例

    GET /gb/tweet/1/_source
    

         返回

    {
      "name": "wangwu"
    }
    

       三,请求体查询

        1,查询所有文档

        默认评分是1,可以通过设置boost来,由于有些代理服务器不支持GET请求带请求体,所以实际中还是要用POST请求。

    GET /gb/_search
    {
      "query": {
        "match_all": {}
      }
    }
    

         返回

    {
      "took": 11,
      "timed_out": false,
      "_shards": {
        "total": 5,
        "successful": 5,
        "skipped": 0,
        "failed": 0
      },
      "hits": {
        "total": 1,
        "max_score": 1,
        "hits": [
          {
            "_index": "gb",
            "_type": "tweet",
            "_id": "1",
            "_score": 1,
            "_source": {
              "name": "wangwu"
            }
          }
        ]
      }
    }
    

         2,分页查询所有文档

    GET /system-log-2019.09/_search
    {
      "query": {
        "match_all": {}
      },
      "from": 0,
      "size": 2
    }
    

         从头开始,每次显示2条第一页返回如下

    {
      "took": 0,
      "timed_out": false,
      "_shards": {
        "total": 5,
        "successful": 5,
        "skipped": 0,
        "failed": 0
      },
      "hits": {
        "total": 60361,
        "max_score": 1,
        "hits": [
          {
            "_index": "system-log-2019.09",
            "_type": "doc",
            "_id": "X9GKbG0BHXMu0O5TBI8U",
            "_score": 1,
            "_source": {
              "message": "Sep 26 15:14:25 salt-test systemd: Reloading.",
              "@version": "1",
              "type": "system-log",
              "host": "salt-test",
              "path": "/var/log/messages",
              "@timestamp": "2019-09-26T07:14:25.503Z"
            }
          },
          {
            "_index": "system-log-2019.09",
            "_type": "doc",
            "_id": "YNGKbG0BHXMu0O5TBI8U",
            "_score": 1,
            "_source": {
              "message": """Sep 26 15:14:25 salt-test filebeat: 2019-09-26T15:14:25.362+0800#011ERROR#011pipeline/output.go:100#011Failed to connect to backoff(elasticsearch(http://192.168.1.4:9200)): Connection marked as failed because the onConnect callback failed: 400 Bad Request: {"error":{"root_cause":[{"type":"invalid_index_name_exception","reason":"Invalid index name [_ilm], must not start with '_', '-', or '+'","index_uuid":"_na_","index":"_ilm"}],"type":"invalid_index_name_exception","reason":"Invalid index name [_ilm], must not start with '_', '-', or '+'","index_uuid":"_na_","index":"_ilm"},"status":400}""",
              "@version": "1",
              "type": "system-log",
              "host": "salt-test",
              "path": "/var/log/messages",
              "@timestamp": "2019-09-26T07:14:25.503Z"
            }
          }
        ]
      }
    }
    

         3,条件查询并排序

        查询host名为salt-test的主机,只显示message和host字段,按时间倒序排列,从头开始页大小为2

    GET /system-log-2019.09/_search
    {
      "query": {
        "match": {
          "host":"salt-test"
        }
      },
      "_source": [
        "host",
        "@timestamp"
        ],
      "sort": [
        {
            "@timestamp": "desc"
        }
      ],
      "from": 0,
      "size": 2
    }
    

     

         4,全文检索

        索引中只要有任意一个匹配拆分后词就可以出现在结果中,只是匹配都越高越的排越前面

    GET /gb/_search
    {
      "query": {
        "match": {
          "name":"wangwu"
        }
      }
    }
    

         

          

  • 相关阅读:
    工资低的.Net程序员,活该你工资低
    React- jsx的使用 使用 camelCase 语法来设置内联样式. React 会在指定元素数字后自动添加 px
    React 使用jsx
    node.js 简介
    转换成数值 parseInt与parseFloat; (toString) 转化为字符串
    函数 封装性划分私有空间
    favicon 不显示的问题总结1
    js进阶 offset
    前端缓存技术
    图片的预加载与懒加载
  • 原文地址:https://www.cnblogs.com/minseo/p/11611369.html
Copyright © 2011-2022 走看看