【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的相关日志。

相关推荐
黄雪超8 小时前
深入MapReduce——MRv1设计
大数据·mapreduce
一张假钞9 小时前
Ubuntu 20.04安装Protocol Buffers 2.5.0
大数据·hadoop
Moehoo猛虎9 小时前
题2025年春节 — 五言绝句一首,Hip-Hop一首
大数据·人工智能·云计算·小年
速融云11 小时前
汽车制造案例 | 搭建车间现场数字可视化管理方案(附解决模板)
大数据·人工智能·汽车·制造·甘特图·数据可视化
碳链价值12 小时前
巴菲特购买比特币
大数据·人工智能·区块链
说私域13 小时前
数字化创新者如何利用开源2+1链动模式AI智能名片S2B2C商城小程序源码重塑市场地位
大数据·人工智能·小程序·开源
喝醉酒的小白14 小时前
Elasticsearch的索引生命周期管理
大数据·elasticsearch·jenkins
申尧强14 小时前
flink StreamGraph解析
大数据·flink
一个java开发15 小时前
hadoop==docker desktop搭建hadoop
java·大数据·hadoop
是理不是里_15 小时前
Elasticsearch有哪些应用场景?
大数据·elasticsearch·搜索引擎