Elasticsearch 基础入门之增删改查(1),身为一个Linux运维程序员Context都没弄明白
最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!
对于数据库而言,都脱离不了对数据的增删改查,本文将从对索引创建、删除、修改配置等和对索引中doc数据进行增删改查操作。使用kibana的dev tools进行操作测试。具体Elasticsearch和Kibana安装和使用,参考之前的文章:Elasticsearch 的开源分析可视化工具–Kibana 安装 & 使用-CSDN博客。
2、Elasticsearch中相关名词解释
| 名词 | 说明 |
| index(索引) | 相当于是数据库 |
| mapping(映射) | 相当于数据库中表结构:字段名称、类型等 |
| doc(行数据) | 相当于数据表中一条行数据 |
| fields(字段) | 相当于数据表中的一列 |
| settings(设置) | 设置索引的参数;例如:分片副本数等 |
3、索引操作
3.1、创建索引
# 1、基本语法
PUT <index_name>
# 2、创建索引指定主分片和副本数量
PUT test_es
{
"settings": {
"number_of_shards": 1, //主分片数量为 1
"number_of_replicas": 1 //每个主分片有一个副本
}
}
3.2、修改索引配置
使用 _setting 只能修改允许动态修改的配置项。
# 1、基本语法
PUT /<index_name>/_settings
# 2、修改副本数量为0
PUT test_es/_settings
{
"number_of_replicas": 0
}
3.2.1、静态配置
只能在创建索引时或在关闭状态的索引上设置。
重要的静态配置:number_of_shards:索引的主分片的个数,默认为 1,此设置只能在创建索引时设置。每个索引的分片的数量上限为 1024,这是一个安全限制,以防止意外创建索引,这些索引分片过多可能因资源分配而破坏集群的稳定性。export ES_JAVA_OPTS=“-Des.index. max_number_of_shards=128” 可以通过在属于集群的每个节点上指定系统属性来修改限制。
3.2.2、动态索引
可以使用 _setting 接口实时修改的配置项。
重要的动态配置
1)、number_of_replicas:每个主分片的副本数。默认为 1,允许配置为 0。
2)、refresh_interval:执行刷新操作的频率,默认为1s. 可以设置 -1 为禁用刷新。
3)、max_result_window:from + size 搜索此索引的最大值。默认为10000。
3.3、删除索引
DELETE <index_name>
3.4、判断索引是否存在
HEAD <index_name>
4、文档(doc)操作
4.1、文档操作类型
新增数据分为两种:create、index。
1)、create:如果在 PUT 数据的时候当前数据已经存在,则会返回失败(不存在则创建,存在则报错);
2)、index:如果在 PUT 数据的时候当前数据已经存在,则数据会被覆盖(可以是创建,也可以是全量替换)。
4.2、创建(create)
# 1、基础语法
PUT /<index_name>/_doc/<_id>?op_type=create
# 2、简化版本
PUT /<index_name>/_create/<_id>/
# 3、示例:
PUT test_es/_create/1 # PUT test_es/_doc/1?op_type=create
{
"id":1,
"name":"weilong"
}
4.3、索引(index) [创建或全量更新文档]
# 1、基础语法
PUT /<index_name>/_doc/<_id>?op_type=index
# 2、简化版本
PUT /<index_name>/_doc/<_id>
4.4、文档的增删改查
4.4.1、增(PUT和POST方式都可以)
PUT /<index_name>/_doc/<_id> # 默认是 index 类型
PUT /<index_name>/_create/<_id>
POST /<index_name>/_doc/<_id> # 不加<id>会随机生成id
POST /<index_name>/_create/<_id> # 不加<id>会随机生成id
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Linux运维工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。




既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Linux运维知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip1024b (备注Linux运维获取)
最后的话
最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!
资料预览
给大家整理的视频资料:

给大家整理的电子书资料:

如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!
一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-XoSinPmm-1712950178200)]
更多推荐




所有评论(0)