【ES实战】索引无法写入场景一

由于线程池满导致索引无法写入

集群上的某个索引突然写不了数据,根据提供的异常信息,表现为写请求被服务端拒绝了,随即做了以下检查,

定位检查

  1. 索引是都被只读了

    获取索引的相关配置,看是否有以下配置

    • index.blocks.read_only

      设置为 true 使索引和索引元数据只读,设置为 false 以允许写入和元数据更改。

    • index.blocks.read_only_allow_delete

      index.blocks.read_only 相同,但允许删除索引以释放资源。

    • index.blocks.read

      设置为true以禁用对索引的读取操作。

    • index.blocks.write

      设置为true以禁用对索引的数据写入操作。 与 read_only 不同,此设置不会影响元数据。 例如,您可以使用write块关闭索引,但不能使用read_only块关闭索引。

    GET indexname
    
  2. 了解索引写入的TPS

    通过业务系统反馈的,或者可以为ES集群接入监控。

  3. 查询索引分片分布情况

    GET _cat/shards/indexName?v
    

    类似结果如下

    index             shard prirep state   docs store ip           node
    gudong20220304001 0     p      STARTED    0  261b 192.168.1.1  es02
    
  4. 查询分片所在节点的线程池情况

    GET /_cat/thread_pool?v&s=node_name
    

    结果类似如下,在实际中发现写的线程池active和queue已经达到最大值,且rejected(拒绝)中有大量的数据。明显是写入线程池不够用了。

    node_name         name                active queue rejected
    es02              analyze                  0     0        0
    es02              fetch_shard_started      0     0        0
    es02              fetch_shard_store        0     0        0
    es02              flush                    0     0        0
    es02              force_merge              0     0        0
    es02              generic                  0     0        0
    es02              get                      0     0        0
    es02              index                    0     0        0
    es02              listener                 0     0        0
    es02              management               1     0        0
    es02              refresh                  0     0        0
    es02              rollup_indexing          0     0        0
    es02              scroll                   0     0        0
    es02              search                   0     0        0
    es02              search_throttled         0     0        0
    es02              snapshot                 0     0        0
    es02              warmer                   0     0        0
    es02              watcher                  0     0        0
    es02              write                    1     0        0
    

    查询相关节点的Hot 线程情况

    GET /_nodes/es02/hot_threads
    

    会在结果中,展示节点的什么线程对CPU占用的信息和一些堆栈信息。

  5. 查询分片所在节点的任务情况,筛选出写任务,找到写入量比较多的索引,

    GET _tasks?nodes=es02&actions=indices:data*
    

    会在结果中的description中展示索引名称

如何处理的

  1. 处理方式

    1. 紧急方式

      服务端:

      • 将写任务过多的分片迁移到别的节点
      • 若写任务过多的分片可以暂停写,将索引配置为只读。避免再持续写,导致压力过大。

      客户端:

      • 暂停写入数据
    2. 友好方式

      服务端:

      • 扩大线程池的线程数和等待队列的大小。
      • 增加熔断机制,对一直占用写请求的任务,进行熔断,或者限流。— 需要调整ES内核代码

      客户端:

      • 对应用程序修改,对写请求进行并发的控制,增加动态变更并发数的方式。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好,C知道在这里,我可以帮助您解决Elasticsearch数据无法写入的问题。以下是一些可能的原因和解决方法: 1. 确认索引是否存在:在写入数据之前,确保您要写入索引已经存在。如果不存在,您可以使用Elasticsearch索引API来创建索引。 2. 检查集群健康状态:使用Elasticsearch的健康检查API(/_cluster/health)来确认集群的健康状态。如果集群处于黄色或红色状态,可能会导致数据写入失败。您可以根据返回的错误信息来诊断和解决问题。 3. 检查文档ID:在写入数据时,确保指定了唯一的文档ID。如果指定的文档ID已经存在,将会更新该文档而不是创建新的文档。如果没有指定文档ID,Elasticsearch将自动生成一个唯一的ID。 4. 检查索引设置:确保您的索引设置允许写入操作。您可以使用Elasticsearch索引设置API(/_settings)来检查和修改索引的设置。 5. 检查文档映射:确保您的索引映射允许写入操作。如果映射中某个字段不允许写入,那么写入操作将会失败。您可以使用Elasticsearch索引映射API(/_mapping)来检查和修改索引的映射。 6. 检查存储空间:确保您的Elasticsearch集群有足够的存储空间来存储新的数据。如果磁盘空间已满,写入操作将会失败。 如果您仍然遇到问题,请提供更多的信息,例如错误消息、Elasticsearch版本以及相关的配置信息,以便更好地帮助您解决问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值