记Elasticsearch 因不合理创建type导致集群故障

故障现象

Pending tasks任务一直有堆积,线上createindex等无法完成。

原因分析

客户端存在一定时写数据脚本,脚本中会不断往统一索引创建type,并写数据,造成大量put mapping任务,而此任务又是高优先级,造成任务堆积,无法很快完成创建索引等操作。

原因理解

先从Elasticsearch pending-task说起:

pendingtask只能由主节点来进行处理,这些任务包括创建索引并将shards分配给节点。任务分优先次序。如果任务的产生比处理速度更快,将会产生堆积。如果存在任务堆积,集群存在较大隐患,需要排查集群的任务,确认原因。

官方说明

另外,在5.6.4版本中,提供了一组TaskManagement API。

在出现故障时,集群中会出现pendting_tasks列表不为0,并且好几个任务处理时间一直较长,有的task甚至超过1min。

curl -XGET http://domain/_cluster/pending_tasks?pretty

priority参数说明:

各字段含义可以参考:

https://blog.csdn.net/napoay/article/details/73100110?locationNum=9&fps=1

 

根据实际存在的task列表来看,是put-mapping任务耗时操作较大。接下来,就需要找到是针对哪个索引的操作会造成这些任务(可以借助kibana monitor或者task API)。

找到异常的索引,排查对应任务,如下是造成异常的脚本任务

对应API为PUT doc(PUT /index/type/id),但不同的是,脚本中的type_name每次不同,造成type不断新增。

在Elasticsearch中,每次新增数据后,会进行索引,但是type增加之后,会put mapping。从实际来看,put-mapping是一个高优先级的操作,而且需要master管理,当mapping数量很大时,会造成后续mapping操作很耗时,而且put-mapping还是一个高优任务,会阻塞其他创建索引等任务。

关于mapping可以参考:https://blog.csdn.net/lvhong84/article/details/23936697

官方说明:

 

实际验证

停掉对应索引写操作之后,pending-task很快消失。

小结

1, 针对某索引不断新增type,会造成putmapping,也是一个非常耗时的任务。

2, Create-fields如果只是监控,需要把type变量固定。

3, 需要对Elasticsearch基本概览了解:http://blog.pengqiuyuan.com/ji-chu-jie-shao-ji-suo-yin-yuan-li-fen-xi/



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要合理创建 Elasticsearch(ES)索引,需要考虑以下几个方面: 1. 确定索引的名称:ES中的索引名称应该简洁明了,能够清楚地表达索引的用途或内容。 2. 确定索引的字段:确定需要存储的字段以及字段的类型。在创建索引时,需要指定每个字段的映射类型,包括文本、数字、日期等等。 3. 确定分片和副本:根据数据量和查询负载来确定分片和副本的数量,以实现最佳性能和可用性。 4. 配置索引分析器:ES中的分析器用于将文本字段拆分成单词,并将这些单词标准化以便于搜索。可以根据需要配置合适的分析器。 5. 配置索引设置:根据需要配置索引的相关设置,包括存储大小、写入限制、刷新间隔等等。 6. 优化索引性能:可以通过调整索引缓存、启用压缩、设置合理的索引刷新间隔等方式来优化索引性能。 创建索引的基本语法如下: ``` PUT /索引名称 { "settings": { "number_of_shards": 分片数量, "number_of_replicas": 副本数量 }, "mappings": { "properties": { "字段名称": { "type": "字段类型" } } } } ``` 例如,创建一个名为“my_index”的索引,包含“title”和“content”两个字段,其中“title”为文本类型,而“content”为长文本类型,可以使用以下命令: ``` PUT /my_index { "settings": { "number_of_shards": 5, "number_of_replicas": 1 }, "mappings": { "properties": { "title": { "type": "text" }, "content": { "type": "text", "analyzer": "english" } } } } ``` 以上是创建索引的基本步骤和语法,根据实际需求,可以进一步配置索引的设置和优化性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值