ES基础(五十二)Hot & Warm 架构与 Shard Filtering
课程代码
# 标记一个 Hot 节点 bin/elasticsearch -E node.name=hotnode -E cluster.name=geektime -E path.data=hot_data -E node.attr.my_node_type=hot # 标记一个 warm 节点 bin/elasticsearch -E node.name=warmnode -E cluster.name=geektime -E path.data=warm_data -E node.attr.my_node_type=warm # 查看节点 GET /_cat/nodeattrs?v # 配置到 Hot节点 PUT logs-2019-06-27 { "settings":{ "number_of_shards":2, "number_of_replicas":0, "index.routing.allocation.require.my_node_type":"hot" } } PUT my_index1/_doc/1 { "key":"value" } GET _cat/shards?v # 配置到 warm 节点 PUT PUT logs-2019-06-27/_settings { "index.routing.allocation.require.my_node_type":"warm" } # 标记一个 rack 1 bin/elasticsearch -E node.name=node1 -E cluster.name=geektime -E path.data=node1_data -E node.attr.my_rack_id=rack1 # 标记一个 rack 2 bin/elasticsearch -E node.name=node2 -E cluster.name=geektime -E path.data=node2_data -E node.attr.my_rack_id=rack2 PUT _cluster/settings { "persistent": { "cluster.routing.allocation.awareness.attributes": "my_rack_id" } } PUT my_index1 { "settings":{ "number_of_shards":2, "number_of_replicas":1 } } PUT my_index1/_doc/1 { "key":"value" } GET _cat/shards?v DELETE my_index1/_doc/1 # Fore awareness # 标记一个 rack 1 bin/elasticsearch -E node.name=node1 -E cluster.name=geektime -E path.data=node1_data -E node.attr.my_rack_id=rack1 # 标记一个 rack 2 bin/elasticsearch -E node.name=node2 -E cluster.name=geektime -E path.data=node2_data -E node.attr.my_rack_id=rack1 PUT _cluster/settings { "persistent": { "cluster.routing.allocation.awareness.attributes": "my_rack_id", "cluster.routing.allocation.awareness.force.my_rack_id.values": "rack1,rack2" } } GET _cluster/settings # 集群黄色 GET _cluster/health # 副本无法分配 GET _cat/shards?v GET _cluster/allocation/explain?pretty
# 标记一个 Hot 节点 bin/elasticsearch -E node.name=hotnode -E cluster.name=geektime -E path.data=hot_data -E node.attr.my_node_type=hot # 标记一个 warm 节点 bin/elasticsearch -E node.name=warmnode -E cluster.name=geektime -E path.data=warm_data -E node.attr.my_node_type=warm # 查看节点 GET /_cat/nodeattrs?v # 配置到 Hot节点 PUT logs-2019-06-27 { "settings":{ "number_of_shards":2, "number_of_replicas":0, "index.routing.allocation.require.my_node_type":"hot" } } PUT my_index1/_doc/1 { "key":"value" } GET _cat/shards?v # 配置到 warm 节点 PUT PUT logs-2019-06-27/_settings { "index.routing.allocation.require.my_node_type":"warm" } # 标记一个 rack 1 bin/elasticsearch -E node.name=node1 -E cluster.name=geektime -E path.data=node1_data -E node.attr.my_rack_id=rack1 # 标记一个 rack 2 bin/elasticsearch -E node.name=node2 -E cluster.name=geektime -E path.data=node2_data -E node.attr.my_rack_id=rack2 PUT _cluster/settings { "persistent": { "cluster.routing.allocation.awareness.attributes": "my_rack_id" } } PUT my_index1 { "settings":{ "number_of_shards":2, "number_of_replicas":1 } } PUT my_index1/_doc/1 { "key":"value" } GET _cat/shards?v DELETE my_index1/_doc/1 # Fore awareness # 标记一个 rack 1 bin/elasticsearch -E node.name=node1 -E cluster.name=geektime -E path.data=node1_data -E node.attr.my_rack_id=rack1 # 标记一个 rack 2 bin/elasticsearch -E node.name=node2 -E cluster.name=geektime -E path.data=node2_data -E node.attr.my_rack_id=rack1 PUT _cluster/settings { "persistent": { "cluster.routing.allocation.awareness.attributes": "my_rack_id", "cluster.routing.allocation.awareness.force.my_rack_id.values": "rack1,rack2" } } GET _cluster/settings # 集群黄色 GET _cluster/health # 副本无法分配 GET _cat/shards?v GET _cluster/allocation/explain?pretty
本文来自博客园,作者:秋华,转载请注明原文链接:https://www.cnblogs.com/qiu-hua/p/14198143.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程
2017-12-27 爬虫python3:TypeError: cannot use a string pattern on a bytes-like object