资讯专栏INFORMATION COLUMN

ES常用基础操作命令及实践

IT那活儿 / 3156人阅读
ES常用基础操作命令及实践
一. ES集群环境



二. ES基本操作命令_cat

1. 基本参数

verbose:显示列名, 请求参数为v

示例: curl localhost:9200/_cat/master?v

help:显示当前命令的各列含义, 请求参数为help. 某些命令部分列默认不显示,可通过help该命令可显示的所有列

示例: curl localhost:9200/_cat/master?help

bytes: 数值列以指定单位显示, 默认转为以kb/mb/gb表示

示例: curl localhost:9200/_cat/indices?bytes=b

header:显示指定列的信息,请求参数为h

示例: curl localhost:9200/_cat/indices?h=i,tm
(显示集群各索引占用多大的空间)


2. 查看segement详细信息(/_cat/segements)

查看各index的segment详细信息,包括segment名, 所属shard, 内存/磁盘占用大小, 是否刷盘, 是否merge为compound文件等. 可以查看指定index的segment信息(/_cat/segments/${index})

例: curl localhost:9200/_cat/segments/new_index_20210621?v


3. 查看index详细信息(/_cat/indices)

查看集群中所有index的详细信息,包括index状态,shard个数(primary/replica),doc个数等,可参考help. 可以查看指定index的信息(/_cat/indices/${index})

示例: curl localhost:9200/_cat/indices?v


4. 查看alias详细信息(/_cat/aliases)

查看集群中所有alias信息,包括alias对应的index, 路由配置等. 可以查看指定alias的信息(/_cat/aliases/${alias})

先给索引创建个别名: curl -XPUT localhost:9200/new_index_20210618/_alias/a1?pretty

示例: curl localhost:9200/_cat/aliases?v


5. 查看shard详细信息(/_cat/shards)

查看各shard的详细情况,包括shard的分布, 当前状态(对于分配失败的shard会有失败原因), doc数量, 磁盘占用情况, shard的访问情况(如所有get请求的成功/失败次数以及对应耗时等). 可以指定index只查看某个index的shard信息(/_cat/shards/${index})

示例: curl localhost:9200/_cat/shards?v


6. 查看单节点磁盘使用情况(/_cat/allocation)

查看单节点的shard分配整体情况

示例: curl localhost:9200/_cat/allocation?v


7. 查看单节点的自定义属性(/_cat/nodeattrs)

查看单节点的自定义属性

示例: curl localhost:9200/_cat/nodeattrs?v


8. 查看集群当前状态(/_cat/health)

查看集群当前状态, 包括data节点个数,primary shard个数等基本信息

示例: curl localhost:9200/_cat/health?v

status列为green时表示集群正常; yellow表示部分shards的primary已分配,replica未分配; red表示部分shard的primary未分配


9. 查看集群各个节点的当前状态(/_cat/nodes)

查看集群各个节点的当前状态, 包括节点的物理参数(包括os/jdk版本, uptime, 当前mem/disk/fd使用情况等), 请求访问情况(如search/index成功和失败的次数)等详细信息

示例: curl localhost:9200/_cat/nodes?v


10. 查看集群master节点(/_cat/master)

查看集群中的master节点

示例: curl localhost:9200/_cat/master?v


11. 查看集群fielddata内存占用情况(/_cat/fielddata)

查看当前集群各个节点的fielddata内存使用情况,默认是关闭的

示例: curl localhost:9200/_cat/fielddata?v


12. 查看集群doc数量(/_cat/count)

查看当前集群的doc数量; 也可显示指定index的doc数量,格式为/_cat/count/${index}

示例: curl localhost:9200/_cat/count/new_index_20210618?v


13. 查看集群的pendingTask情况(/_cat/pending_tasks)

查看当前集群的pending task(等待事件),测试环境没业务

示例: curl localhost:9200/_cat/pending_tasks?v

14. 查看集群各节点的plugin信息(/_cat/plugins)

查看集群各个节点上的plugin(插件)信息,测试环境没有安装插件

示例: curl localhost:9200/_cat/plugins?v


三. ES索引基本操作命令

1. 查询es中所有索引,所有已存在的索引

curl localhost:9200/_cat/indices?v


2.创建新的索引【索引要求是全小写字符,可以有下划线隔开】
curl -H"Content-Type: application/json" -XPUT localhost:9200/new_index_20210618?pretty -d{
  "settings":{
    "number_of_replicas":3,
    "number_of_shards":9
    },
  "mappings": {
     "user": {
       "properties": {
          "name": {
            "type":"text"
          },
          "age":{
            "type":"integer"
          },
          "profession":{
            "type":"text"
          }
        }
      }
   }
}

出现这个的原因是,elasticsearch7默认不在支持指定索引类型,默认索引类型是_doc,如果想改变,则配置include_type_name: true 即可(官方文档说,无论是否可行,建议不要这么做,因为elasticsearch8后就不在提供该字段)。

官方文档:

https://www.elastic.co/guide/en/elasticsearch/reference/current/removal-of-types.html


所以在Elasticsearch7中应该这么创建索引,也可创建索引后再修改mapping(pretty输出结果已json形式输出)

curl -H"Content-Type: application/json" -XPUT localhost:9200/new_index_20210618?pretty -d{
  "settings":{
    "number_of_replicas":3,
    "number_of_shards":9
    },
  "mappings": {
       "properties": {
          "name": {
            "type":"text"
          },
          "age":{
            "type":"integer"
          },
          "profession":{
            "type":"text"
          }
        }
   }
}


3. DELETE删除索引

示例: curl -XDELETE localhost:9200/new_text_202106018?pretty

4. 索引重命名,ES不支持索引重命名,只能将原索引复制到新索引

curl -H"Content-Type: application/json" -XPOST localhost:9200/_reindex -d{
  "source": {
    "index": "new_index_20210621"
  },
  "dest": {
    "index": "new_index_20210618"
  }
}

5. 开启关闭索引,索引关闭后只能查看索引配置信息,不能对索引的数据进行读写操作

关闭: 

curl -H "Content-Type: application/json" -XPOST localhost:9200/test1/_close?pretty

开启: 

curl -H "Content-Type: application/json" -XPOST localhost:9200/test1/_open?pretty


四. ES映射基本操作命令

1.查询索引的mappings(映射,相当于数据库的表结构)

curl -XGET localhost:9200/test1/_mappings?pretty

2. 修改索引的mapping,添加Createtime字段字段类型是date(*ES mapping在建好之后不可以更改字段类型,也不支持删除)

curl -H "Content-Type: application/json" -XPUT localhost:9200/test1/_mapping?pretty -d{"properties":{"name":{"type":"text"},"age":{"type":"text"},"profession":{"type":"text"},"Createtime":{"type":"date","format":"yyyy-MM-dd HH:mm:ss"}}}


五. ES数据(文档)基本操作命令

1.创建新的索引库test2

curl -XPUT localhost:9200/test2?pretty

2.像新建的test2索引库中插入一条数据

数据插入后会自动生成mapping,字段类型默认为text,时间字段类型为date

curl -H "Content-Type: application/json" -XPUT localhost:9200/test2/_doc/1?pretty -d  {"name":"张三","age":"23","profession":"法外狂徒","Createtime":"2021-06-25"}

3. 查询新插入的数据

curl -XGET localhost:9200/test2/_doc/1?pretty

4. 修改数据,每修改一次_version加1

curl -H "Content-Type: application/json" -XPUT localhost:9200/test2/_doc/1?pretty -d {"name":"张三更新","age":"230"}

即使用相同的新增命令操作相同的ID,数据不同

或者使用_update更新数据

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_doc/1/_update?pretty -d {"doc":{"name":"张三更新","age":"2300"}}

5. 使用简单的脚本修改数据

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_doc/1/_update?pretty -d {"script" : "ctx._source.age += 5"}

6. 根据ID删除数据

curl -XDELETE localhost:9200/test2/_doc/1?pretty

7. _bukl命令批量操作

curl -H "Content-Type: application/json"  -XPOST localhost:9200/test2/_doc/_bulk?pretty -d
{"update":{"_id":"1"}}
{"doc": {"name":"赵思妹妹","age":"25"}}
{"update":{"_id":"2"}}
{"doc":{"name":"钱老板","age":"50"}}
{"delete":{"_id":"3"}}
{"index":{"_id":"4"}}
{"name":"尼古拉斯","age":"1200"}

8. 使用bulk命令导入数据集文件json文件

创建test.json文件,确保ES用户有读取该文件的权限。

Vi test.json
{"index":{"_id":"10"}}
{"name":"张三10","age":10}
{"index":{"_id":"11"}}
{"name":"张三11","age":11}
{"index":{"_id":12}}
{"name":"张三12","age":12}
{"index":{"_id":"13"}}
{"name":"张三13","age":13}
{"index":{"_id":"14"}}
{"name":"张三14","age":14}
{"index":{"_id":15}}
{"name":"张三15","age":15}
指定要导入的  索引、type、使用bulk命令  @符号后面跟json文件的绝对路径

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_doc/_bulk?pretty --data-binary @/home/test.json

查看索引文档数为9,增加了5个


六. ES _search查询命令

1. 查询某个索引中的所有数据

curl -H "Content-Type: application/json" -XGET localhost:9200/new_index_20210621/_search?pretty -d {"query":{ "match_all":{}}}

2. 查询某个索引中的2条数据

(如果不指定size,默认返回10条,按照ID排序)

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_search?pretty -d
{
    "query":{
        "match_all":{

        }
    },
    "size":2
}

3. 查询某个索引中的2条数据,从第二条数据开始

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_search?pretty -d
{
    "query":{
        "match_all":{

        }
    },
    "from":2,
    "size":2
}

4. 查询的部分字段,只返回name和age列

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_search?pretty -d
{
    "query":{
        "match_all":{

        }
    },
    "_source":[
        "name",
        "age"
    ],
    "size":2
}


5. 条件匹配查询,查询age=10的数据

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_search?pretty -d
{
    "query":{
        "match":{
            "age":10
        }
    }
}

6. 布尔查询 bool

and查询,必须同时满足age=10,name中包含“张三”

must表示所有查询必须都为真才被认为匹配

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_search?pretty -d
{
    "query":{
        "bool":{
            "must":[
                {
                    "match":{
                        "age":10
                    }
                },
                {
                    "match":{
                        "name":"张三"
                    }
                }
            ]
        }
    }
}


7. 布尔查询bool

or查询 age=10 或者 name中包含“张三” 满足其中一项就可以

should 表示查询列表中只要有任何一个为真则认为匹配

curl -H "Content-Type: application/json" -XPOST localhost:9200/test2/_search?pretty -d
{
    "query":{
        "bool":{
            "should":[
                {
                    "match":{
                        "age":10
                    }
                },
                {
                    "match":{
                        "name":"张三"
                    }
                }
            ]
        }
    }
}

相关阅读:

蔡素,公众号:IT那活儿Elastic search 集群搭建


END


更多精彩干货分享

点击下方名片关注

IT那活儿

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/129827.html

相关文章

  • 前端资源系列(4)-前端学习资源分享&前端面试资源汇总

    摘要:特意对前端学习资源做一个汇总,方便自己学习查阅参考,和好友们共同进步。 特意对前端学习资源做一个汇总,方便自己学习查阅参考,和好友们共同进步。 本以为自己收藏的站点多,可以很快搞定,没想到一入汇总深似海。还有很多不足&遗漏的地方,欢迎补充。有错误的地方,还请斧正... 托管: welcome to git,欢迎交流,感谢star 有好友反应和斧正,会及时更新,平时业务工作时也会不定期更...

    princekin 评论0 收藏0
  • 前端文档收集

    摘要:系列种优化页面加载速度的方法随笔分类中个最重要的技术点常用整理网页性能管理详解离线缓存简介系列编写高性能有趣的原生数组函数数据访问性能优化方案实现的大排序算法一怪对象常用方法函数收集数组的操作面向对象和原型继承中关键词的优雅解释浅谈系列 H5系列 10种优化页面加载速度的方法 随笔分类 - HTML5 HTML5中40个最重要的技术点 常用meta整理 网页性能管理详解 HTML5 ...

    jsbintask 评论0 收藏0
  • 前端文档收集

    摘要:系列种优化页面加载速度的方法随笔分类中个最重要的技术点常用整理网页性能管理详解离线缓存简介系列编写高性能有趣的原生数组函数数据访问性能优化方案实现的大排序算法一怪对象常用方法函数收集数组的操作面向对象和原型继承中关键词的优雅解释浅谈系列 H5系列 10种优化页面加载速度的方法 随笔分类 - HTML5 HTML5中40个最重要的技术点 常用meta整理 网页性能管理详解 HTML5 ...

    muddyway 评论0 收藏0
  • [译] 前端攻略-从路人甲到英雄无敌二:JavaScript 与不断演化的框架

    摘要:一般来说,声明式编程关注于发生了啥,而命令式则同时关注与咋发生的。声明式编程可以较好地解决这个问题,刚才提到的比较麻烦的元素选择这个动作可以交托给框架或者库区处理,这样就能让开发者专注于发生了啥,这里推荐一波与。 本文翻译自FreeCodeCamp的from-zero-to-front-end-hero-part。 继续译者的废话,这篇文章是前端攻略-从路人甲到英雄无敌的下半部分,在...

    roadtogeek 评论0 收藏0
  • 【译】前端练级攻略

    摘要:由于系统变得越来越复杂,人们提出了称为预处理器和后处理器的工具来管理复杂性。后处理器在由预处理器手写或编译后对应用更改。我之前建议的文章,,也涵盖了预处理器相关的知识。 译者:前端小智 原文:medium.freecodecamp.org/from-zero-t… medium.freecodecamp.org/from-zero-t… 我记得我刚开始学习前端开发的时候。我看到了很多文章及...

    wuyumin 评论0 收藏0

发表评论

0条评论

IT那活儿

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<