【ES实战】治理项之索引模板相关治理

索引模板治理

文章目录

问题现象

在集群索引新建时,索引的分片比较耗时。分钟级别的检测可以捕获到red状态。可能出现影响该索引的读写。过多的分片会应该集群的稳定。

分析思路

查询集群的索引的状态和分片数量,识别索引与分片的数量是否合理。

操作步骤

  1. 查询集群中的索引看分片数量

    shell 复制代码
    GET _cat/indices?v&s=index

    prirep代表主分片数和副本分片数

  2. 查询集群中的索引分片大小是否合理

    shell 复制代码
    GET _cat/shards?v&s=index

    store 代表存储大小

  3. 通过上述发现一些不合理的索引有规律性(由索引模板应用而来)

    查看模板列表

    shell 复制代码
    GET _cat/templates?v&s=name

    template代表索引名称匹配模式(6.0版本以后为index_patterns

    查询单个模板的详细配置

    shell 复制代码
    GET _template/索引模板名称

问题

  1. 如何识别索引属于那个模板生成???

    原生情况下,只能有索引名称进行模式匹配。

  2. 如何模板的版本与生成的索引之间的关系

    模板是可以变化,如果识别索引是那个状态下的模板呢

  3. 索引的数据量的变化不是很快,周期往往是半年或者一年,

    所以操作程序化的收益不大

程序化方案

索引与索引模板增加分片数校验管理

  • 索引模板管理信息中增加版本号,索引名称管理信息中增加,索引来源(模板-模板名称?模板ID?)
  • 索引模板应用的索引,由平台定时任务创建索引时,同时增加模板版本号信息。
  • 查询管理平台中由模板生成的索引,索引要求:当前月,当前日,前一月,前一日
  • 检测索引的分片设置是否合理,如果不合理(分片数过多或者过少)则由索引信息中绑定的索引模板,去查询模板的设置,如果模板设置不在合理范围则进行告警。
  • 模板生成的数据一般变化不会太大,可以对模板增加有一个检查时间,是检查超过半年或者1年的模板。

彩蛋

已知条件,知晓任务的application id

目标通过Yarn Web UI查询Task Manager日志

相关配置
  • yarn.resourcemanager.webapp.address:yarn集群的RM web地址
  • yarn.nodemanager.webapp.address:yarn集群的NM web访问地址
查询已停止的Flink任务

拼接yarn集群的RM管理web地址与ApplicationId

http://{yarn.resourcemanager.webapp.address}/cluster/app/{ApplicationId}

http://demo.com:8080/cluster/app/application_1683333308174_19078

通过上述地址,打开任务的Yarn Web UI

点击Logs超链接,跳转到Job containerlogs 选择页,浏览器的地址会发生变化,跳转到执行Job Manager的NM上。此时也可以通过地址栏知道Node Manager的yarn.nodemanager.webapp.address的值(域名端口)。

打开jobmanager.log

在日志中搜索Registering TaskManager with ResourceID

log 复制代码
2025-01-13 17:48:33,996 INFO flink-pekko.actor.default-dispatcher-19 ActiveResourceManager: Registering TaskManager with ResourceID container_e10_1683333308174_19078_01_000002(demo01:8043) (pekko.tcp://flink@demo01:31384/user/rpc/taskmanager_0) at ResourceManager

发现有一个task 的 ResourceID 是container_e10_1683333308174_19078_01_000002(容器ID),在demo01节点上执行。

此时开始拼接此task日志地址

http:{执行Task机器}:{yarn.nodemanager.webapp.address的端口}/node/containerlogs/{task的ResourceID}/{user}

举例:http://demo01:8088/node/containerlogs/container_e10_1683333308174_19078_01_000002/huatuo

此地址就可以打开taskmanager.log页面了

查询未停止的Flink任务

拼接yarn集群的RM管理web地址与ApplicationId

http://{yarn.resourcemanager.webapp.address}/cluster/app/{ApplicationId}

打开任务的Yarn Web UI

点击[ApplicationMaster]超链接,跳转到Flink的Web页面。点击导航菜单Task Managers 右侧会展示所有的Task,点击ID进行跳转至Task详细页。

在Task详细页,选择Logs栏会展示这个task的相关日志。

相关推荐
爱看科技几秒前
科技新突破!微美全息(NASDAQ:WIMI)研发保留运动想象脑机接口“方差密钥”技术
大数据·人工智能·科技
中科岩创9 分钟前
青海某公路水渠自动化监测服务项目
大数据·人工智能·物联网
武子康16 分钟前
大数据-131 Flink CEP 实战 24 小时≥5 次交易 & 10 分钟未支付检测 案例附代码
大数据·后端·flink
Likeadust1 小时前
新版视频直播点播平台EasyDSS用视频破局,获客转化双提升
大数据·音视频
Aurora_eye1 小时前
记录之Ubuntu22.4虚拟机及hadoop为分布式安装
大数据·hadoop·分布式
Kay_Liang2 小时前
大语言模型如何精准调用函数—— Function Calling 系统笔记
java·大数据·spring boot·笔记·ai·langchain·tools
链上日记2 小时前
AIOT定义Web3健康新纪元:从智能硬件到健康金融
大数据
一人の梅雨3 小时前
大麦网关键词列表接口的产业级实现:从演出聚合到市场趋势预测的全维度技术方案
大数据·数据库·人工智能
自由自在的小Bird4 小时前
TDengine
大数据·时序数据库·tdengine
言之。13 小时前
大模型嵌入 vs ES:语义搜索与关键字搜索
大数据·elasticsearch·搜索引擎