控制集群的再平衡

默认情况下,Elasticsearch视图把分片和副本在集群中均衡分布。大多数情况下是好的,但有时候想人为控制此行为。

再平衡

再平衡是在集群的不同节点之间移动分片的过程。

集群的就绪

索引由分片和副本构成。主分片用于新文档被编入索引以及更新或删除,或者索引发生任何变化时。副本从主分片获取数据。

当主分片都被分配到集群中的节点上,也就达到了黄色状态,集群就已经就绪,可以对外提供服务,此时Elasticsearch会初始化副本。

集群再平衡设置

Elasticsearch允许控制再平衡过程,通过设置elasticsearch.yml文件中的几个属性,或使用Elasticsearch REST API。

控制再平衡何时开始

cluster.routing.allocation.allow_rebalance

该属性的取值:

  • always:表名再平衡可以在需要时随时开始
  • indices_primaries_active:所有主分片都初始化后,再平衡才会开始。
  • indices_all_active:默认设置,所有分片和副本都初始化后,再平衡才会开始。

控制同时在节点移动的分片数量

cluster.routing.allocation.cluster_concurrent_rebalance

指定整个集群中同时可以在节点间移动的分片数量。如果集群由很多节点组成,可以提高这个值。默认值2。

控制单个节点上同时初始化的分片数量

cluster.routing.allocation.node_concurrent_recoveries

设置Elasticsearch在单个节点上一次可以初始化多少分片。分片还原过程是非常耗I/O的,默认是2.

控制单个节点上同时初始化的主分片数量

cluster.routing.allocation.node_initial_primaries_recoveries

控制分配的分片类型

cluster.routing.allocation.enable

控制允许分配哪种类型的分片。取值如下:

  • all:默认值,所有类型的分片都可以被分配
  • primaries:只分配主分片,不要分配副本
  • new_primaries:只分配新创建的主分片
  • none:完成禁用了分片的分配

控制单个节点上的并发流数目

indices.recovery.concurrent_streams

允许控制一个节点上一次可以打开多少流,以便从目标分片中恢复一个分片。默认值是3。

控制分片和副本的分配

显式控制分配

  1. 指定节点参数
    假设希望把更强大的编号为1和2的节点放置在一个叫zone_one的区域,编号3和4的节点资源较少,放在叫zone_two的区域。
  2. 配置
    在节点1和节点2的elasticsearch.yml配置文件中添加node.zone: zone_one属性。在节点3和节点4的elasticsearch.yml文件中添加类似的node.zone:zone_two。
  3. 索引的创建
    现在创建shop索引。放在更强的节点:

    curl -XPUT 'http://localhost:9200/shop' -d'{
    "setting":{
    "index":{
    "routing.allocation.include.zone":"zone_one"
    }
    }
    }'

意味着希望把shop索引放到node.zone属性等于zone_one的节点。

promotions索引应该放在所有节点,命令如下:

curl -XPOST 'http://localhost:9200/promotions'
curl -XPUT 'http://localhost:9200/promotions/_settings' -d'{
"setting":{
"index":{
"routing.allocation.include.zone":"zone_one, zone_two"
}
}
}'

第一个命令创建索引,第二个命令更新index.routing.allocation.include.zone属性的值。

  1. 排除节点的分配
  2. 节点需求属性
    指定分片必须匹配某种规则才能分配到给定节点上。

    index.routing.allocation.require

curl -XPOST 'http://localhost:9200/promotions/_settings' -d'{
"index.routing.allocation.require.size":"big_node",
"index.routing.allocation.require.zone":"zone_one"
}'

Elasticsearch将只会把promotions索引分片分配到node.size属性等于big_node且node.zone属性等于zone_one的节点上。

  1. 使用IP地址分配分片
    使用IP地址来指定应该包含排除哪些节点用来做分片和副本的分配。
  2. 基于磁盘的分片分配
    允许基于节点的磁盘使用情况来设置分配规则,因此不会有耗尽磁盘空间或类似的问题。
  • 启动基于磁盘的分片分配:基于磁盘的分片分配默认是禁用的。可以设置cluster.routing.allocation.disk.threshold_enabled属性为true来启用。
  • 配置基于磁盘的分片分配

    第二和第三个属性值也可以是一个绝对值。

集群范围的分配


希望把所有新索引都放置在IP地址为10.1.2.10和10.1.2.11的节点上。

每个节点上的分片和副本数量

指定单一节点上为单一索引最多可以放置多少分片

curl -XPOST 'localhost:9200/shop/_settings' -d'{
"index.routing.allocation.total_shards_per_node":1
}'

该属性可以放在配置文件中。

手动移动分片和副本

使用Elasticsearch的_cluste/reroute REST端点。
有以下可用的操作:

  • 把分片从一个节点移动到另一个节点
  • 取消分片的分配
  • 强制分片的分配

移动分片


move命令允许移动由index属性指定的索引分片和副本。shard属性是要移动的分片的编号。最后,from_node属性指定从哪个节点上移动分片。

取消分片分配


上述命令将取消es_node_one节点上shop索引编号为0的分片分配。

强制分片的分配

分配一个未分配的分片到指定节点上。

预热

Elasticsearch允许为类型和索引定义预热查询。

定义一个新的预热查询

预热查询和其他查询类似,只是它存储在Elasticsearch一个特殊的名为_warmer的索引中。

把上述查询存储为library索引的预热查询,执行以下命令:

上述命令将注册一个名为tags_warming_query的预热查询。一个索引可以有多个预热查询,但是名字唯一。

添加一个预热查询后,Elasticsearch允许一个新段执行搜索之前,会在那个段上执行定义的预热查询。允许elasticsearch和操作系统缓存数据,以此来加快搜索。

获取定义的预热查询



删除一个预热查询

禁用预热功能

查询的选择

通常选择执行起来昂贵和需要填充缓存的查询需要预热。如:基于索引中的字段做切面和排序,父子查询,常用的过滤器查询。也可以通过日志查找不尽人意的查询。


注意:过多的预热查询,也会影响Elasticsearch的性能

Elasticsearch--集群管理_再平衡&预热的更多相关文章

  1. Elasticsearch集群 管理

    第7章 深入Elasticsearch集群 启动一个Elasticsearch节点时,该节点会开始寻找具有相同集群名字并且可见的主节点.如 果找到主节点,该节点加入一个已经组成了的集群:如果没有找到, ...

  2. elasticsearch集群管理工具head插件(转)

    elasticsearch-head是一个elasticsearch的集群管理工具,它是完全由html5编写的独立网页程序,你可以通过插件把它集成到es 插件安装方法1: 1.elasticsearc ...

  3. Elasticsearch集群管理工具head插件安装

    Elasticsearch-head是一个elasticsearch的集群管理工具,它是完全由html5编写的独立网页程序,你可以通过插件把它集成到es.或直接下载源码,在本地打开index.html ...

  4. elasticsearch 集群管理(集群规划、集群搭建、集群管理)

    一.集群规划 搭建一个集群我们需要考虑如下几个问题: 1. 我们需要多大规模的集群? 2. 集群中的节点角色如何分配? 3. 如何避免脑裂问题? 4. 索引应该设置多少个分片? 5. 分片应该设置几个 ...

  5. Elasticsearch集群管理

    ES通过设置[节点的名字]和[集群的名字],就能自动的组织相同集群名字的节点加入到集群中,并使很多的技术对用户透明化. 如果用户想要管理查看集群的状态,可以通过一些REST API来实现. 其他的ES ...

  6. 大规模Elasticsearch集群管理心得

    转载:http://elasticsearch.cn/article/110 ElasticSearch目前在互联网公司主要用于两种应用场景,其一是用于构建业务的搜索功能模块且多是垂直领域的搜索,数据 ...

  7. Elasticsearch集群管理之添加、删除节点

    1.问题抛出 1.1 新增节点问题 我的群集具有黄色运行状况,因为它只有一个节点,因此副本保持未分配状态,我想要添加一个节点,该怎么弄? 1.2 删除节点问题 假设集群中有5个节点,我必须在运行时删除 ...

  8. elasticsearch系列八:ES 集群管理(集群规划、集群搭建、集群管理)

    一.集群规划 搭建一个集群我们需要考虑如下几个问题: 1. 我们需要多大规模的集群? 2. 集群中的节点角色如何分配? 3. 如何避免脑裂问题? 4. 索引应该设置多少个分片? 5. 分片应该设置几个 ...

  9. 数据源管理 | 搜索引擎框架,ElasticSearch集群模式

    本文源码:GitHub·点这里 || GitEE·点这里 一.集群环境搭建 1.环境概览 ES版本6.3.2,集群名称esmaster,虚拟机centos7. 服务群 角色划分 说明 en-maste ...

随机推荐

  1. 暴力破解zip文件

    #coding=utf-8 """ 用户输入-z参数指定要破解的zip文件,输入-d参数输入字典文件,即可暴力破解加密的zip文件 """ ...

  2. Android 怎样在java/native层改动一个文件的权限(mode)与用户(owner)?

    前言          欢迎大家我分享和推荐好用的代码段~~ 声明          欢迎转载.但请保留文章原始出处:          CSDN:http://www.csdn.net        ...

  3. (21) java web的struts2框架的使用

    在javaweb开发过程中,如果只使用servlet,jdbc,jsp进行开发,也可以遵从MVC的模式,这时候,servlet相当于control层,属于负责处理业务逻辑的控制器,同时也需要对获取和返 ...

  4. Javascript 解析字符串生成 XML DOM 对象。

    Javascript 接收字符串生成 XML DOM 对象.实测对 Firefox .IE6 有效.可用于解析 ajax 的服务器响应结果,也可用于解析自定义字符串.​1. [代码]函数   ppt模 ...

  5. ACTION中获得数据的几种方式

    1.第一种是通过公司封装的方法. 2.第二种:是通过IF方法判断 3.第三种是通过:set/get获得

  6. idea output 悬浮浮动问题

    参考:https://www.cnblogs.com/thinkingandworkinghard/p/6306800.html 点这个就ok

  7. 烹调方案 (DP)

    传送门 一道非常好的DP.看这个可能会觉得与01背包很像,不过这个的问题在于现做的菜肴会影响到后面的菜肴的价值. 我们在进行01背包DP时,一件物品的价值是不随着其被枚举的位置改变而改变的,但是这道题 ...

  8. Django 缓存 使用 Redis Memcached 为网站提速

    RedisRedis是一种键值对类型的内存数据库,读写内存比读写硬盘快,我们在Django里面使用Redis非常方便,下面给出详细步骤 基于Ubuntu 1. 安装Redis和django-redis ...

  9. 聊聊Shiro

    Shiro是项目中用的比较多Java安全框架,能满足大多数项目的安全认证.授权流程.相比SpringSecurity的复杂重量级,它更简单易用. Shiro中最关键的两个概念是认证和授权,前者解决确认 ...

  10. String模块ascii_letters和digits

    Python3中String模块ascii_letters和digits方法,其中ascii_letters是生成所有字母,从a-z和A-Z,digits是生成所有数字0-9. 示例如下: Pytho ...