IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 【ES实战】索引无法写入场景一 -> 正文阅读

[大数据]【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内核代码

      客户端:

      • 对应用程序修改,对写请求进行并发的控制,增加动态变更并发数的方式。
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-06 13:08:12  更:2022-03-06 13:10:35 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 19:56:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码