管理平衡

Clustrix Rebalancer被设计成自动作为后台进程运行,以便跨集群重新平衡数据。介绍如何配置和监视rebalancer,但是大多数部署不需要用户干预。

Rebalancer主要通过一组全局变量进行管理,可以通过几个系统表进行监控。如Rebalancer一节所述,Rebalancer应用许多操作,如复制、移动复制和分割片,以保持集群中数据的最佳分布。它被设计成以一种最小化对用户查询影响的方式执行这些操作,并且几乎不需要管理操作。但是,在某些情况下,您可能希望增加或减少rebalancer的侵略性,例如在添加节点之后快速地重新平衡集群,或者在高负载期间消除对用户查询的任何可能干扰。

监控Rebalancer

表rebalancer_activity_log维护当前和过去rebalancer工作的记录。要查看最近的活动,order by started,如下所示。您还可以筛选当前执行的rebalancer操作,其中finished为NULL。

检查最近的Rebalancer活动

sql> select * from system.rebalancer_activity_log order by started desc limit ;
+---------------------+-------------+-----------------------------+----------+---------------+------------------------------+------------+---------------------+---------------------+-------+
| id | op | reason | database | relation | representation | bytes | started | finished | error |
+---------------------+-------------+-----------------------------+----------+---------------+------------------------------+------------+---------------------+---------------------+-------+
| | rerank | distribution read imbalance | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | rerank | distribution read imbalance | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | slice split | slice too big | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | rerank | distribution read imbalance | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | slice split | slice too big | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | rerank | distribution read imbalance | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | slice split | slice too big | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | rerank | distribution read imbalance | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | rerank | distribution read imbalance | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
| | slice split | slice too big | statd | statd_history | __idx_statd_history__PRIMARY | | -- :: | -- :: | NULL |
+---------------------+-------------+-----------------------------+----------+---------------+------------------------------+------------+---------------------+---------------------+-------+
rows in set (0.32 sec)

对于正在进行的rebalancer操作的目标/目的地等细节,连接(使用id) rebalancer_activity_targets、rebalancer_copy_activity或rebalancer_splits。这些是vrels (与实际表相对的虚拟关系),因此只在活动期间填充。

配置Rebalancer

rebalancer的性能是由几个全局变量控制的。

  • rebalancer_global_task_limit:指定并发rebalancer操作的数量,适用于所有rebalancer操作。
  • task_rebalancer_%_interval_ms:定义特定rebalancer任务启动时的间隔时间。
  • rebalancer_rebalance_task_limit:控制并发再平衡任务的数量。
  • rebalancer_vdev_task_limit:限制触及单个设备的并发rebalancer操作的数量

任务的频率决定了操作(如rebalancer移动)进入队列的频率。当有许多小容器时,复制和移动只需几秒钟。因此,30秒的默认频率可能意味着rebalancer队列操作的频率低于它所能达到的频率。大多数rebalancer任务一次只对有限数量的操作进行排队,这是实现理想平衡随时间变化所需的操作。值得注意的例外是SOFTFAIL,它将在节点或磁盘发生softfailed时对所有要执行的工作进行排队。

对于reprotect之外的操作,rebalancer在启动事务后暂停5秒(默认),然后开始从源到目标副本的实际复制。这样做是为了减少未完成的用户事务与rebalancer操作冲突的机会,在这种情况下,用户事务将被取消,并出现以下错误:

MVCC serializable scheduler conflict

请注意,reprotect具有更高的优先级,并且不应用此延迟。

以下是调优rebalancer设置的一些常见用例。请咨询Clustrix支持来更改下面没有讨论的参数

增加rebalance性能

根据设计(如Rebalancer中所述),Rebalancer采用一种比较悠闲的方式跨集群重新平衡数据。由于节点之间的数据不平衡通常需要一些时间才能表现出来,并且通常不会导致显著的性能问题,所以这通常是可以接受的。然而,在某些情况下,更迅速地重新平衡是可取的:

  • 在将集群扩展到更多节点之后,特别是在负载非常低的情况下(或在评估情况下)
  • 在替换失败的节点之后,平衡工作负载对于满足性能需求至关重要

以下是增加rebalancer性能的建议改变:

sql> set global rebalancer_rebalance_task_limit = ;
sql> set global rebalancer_vdev_task_limit = ;
sql> set global task_rebalancer_rebalance_distribution_interval_ms = ;
sql> set global task_rebalancer_rebalance_interval_ms = ;

如果这些设置导致负载过大,则减少rebalancer_rebalance_task_limit或rebalancer_vdev_task_limit。

一旦rebalancer完成,重置这些全局变量为ClustrixDB的默认值:

sql> SET GLOBAL variable_name = DEFAULT; 

提高 SOFTFAIL 性能

正如在管理故障和恢复中所描述的,SOFTFAIL是一种从节点(或磁盘)移动所有数据的方法,用于准备使节点退役或替换。通过正确使用软失效,系统保持对所有数据的充分保护;如果节点在没有软失效的情况下被删除,则会出现一个窗口(直到重新保护完成),其中的一个故障可能会导致数据丢失

软失效被rebalancer视为高优先级。它与重新平衡不同,因为每个任务的限制和任务间隔不适用。改变这两个全局变量可以增加SOFTFAIL的性能:

sql> set global rebalancer_global_task_limit = ;
sql> set global rebalancer_vdev_task_limit = ;

如果这些设置导致负载过大,则减少rebalancer_global_task_limit或rebalancer_vdev_task_limit。

一旦rebalancer完成,重置这些全局变量为ClustrixDB的默认值:

sql> SET GLOBAL variable_name = DEFAULT; 

禁用Rebalancer

禁用Rebalancer语法:

sql> set global rebalancer_optional_tasks_enabled = false;

这将禁用重新排序、拆分、重新分发和重新平衡任务。rebalancer_optional_tasks_enabled的值取代了用于配置单个rebalancer任务的全局变量中的值。

不要长时间禁用Rebalancer,因为Rebalancer在保持最佳数据库性能方面起着至关重要的作用

不应该禁用用于重新保护数据的Rebalancer任务(task_rebalancer_reprotect_interval_ms)。

全局变量

以下全局变量影响Rebalancer活动。注意,这些变量并不适用于单个会话。

 
 
 
Name
Description
Default Value
rebalancer_global_task_limit 同时执行rebalancer操作的最大数量。 16
rebalancer_rebalance_task_limit 每次调度rebalancer_imbalanced和rebalancer_rebalance_distribution的最大操作数。 2
rebalancer_rebalance_threshold 总体写负载变化的最小系数,将触发重新平衡活动。 0.05
rebalancer_reprotect_queue_interval_s 在这么多秒内,排队的副本被认为是健康的,以便在rebalancer_reprotect开始复制之前,让丢失的节点有机会重新联机。 600
rebalancer_split_threshold_kb

rebalancer分割片的大小。

1048576
rebalancer_vdev_task_limit 针对一个设备的最大并发rebalancer操作数。 1
task_rebalancer_rebalance_distribution_interval_ms 运行周期性任务之间的毫秒数为“rebalancer_rebalance_distribution”。指定0以禁用定期任务。 30000
task_rebalancer_rebalance_interval_ms 运行周期性任务之间的毫秒数为“rebalancer_rebalance”。指定0以禁用定期任务 30000
task_rebalancer_reprotect_interval_ms 运行周期性任务“rebalancer_reprotect”之间的毫秒数。指定0以禁用定期任务 15000
task_rebalancer_split_interval_ms 运行周期性任务之间的毫秒数为“rebalancer_split”。指定0以禁用定期任务。 30000
task_rebalancer_zone_balance_interval_ms 运行周期性任务之间的毫秒数为“rebalancer_zone_balance”。指定0以禁用定期任务。 60000
task_rebalancer_zone_missing_interval_ms 运行周期性任务之间的毫秒数“rebalancer_zone_missing”。指定0以禁用定期任务. 60000
 

16. ClustrixDB Rebalancer的更多相关文章

  1. 30. ClustrixDB 分布式架构/Rebalancer

    Rebalancer是一个自动化系统,用于维护集群中数据的健康分布.通过修改数据的分布和位置来响应“不健康”集群是Rebalancer的工作.Rebalancer是一个在线进程,它影响对集群的更改,对 ...

  2. 35. ClustrixDB 减少device1大小

    ClustrixDB中的device1文件用于所有数据库数据.撤消日志.临时表.binlog和ClustrixDB系统对象.ClustrixDB确保device1文件在集群的所有节点上大小相同.一旦得 ...

  3. 34. ClustrixDB 降低集群的容量-Flex down

    有时,可能需要减少集群的容量: 减少高峰事件后的运营成本 为其他目的分配服务器. 删除故障硬件.(参见删除ALTER CLUSTER以删除永久失败的节点.) 在ClustrixDB中缩小集群的过程很简 ...

  4. 33. ClustrixDB 扩展集群的容量-Flex up

    ClustrixDB被授权为每个节点的最大核数以及集群的最大节点数.如果需要扩展许可证,请联系Clustrix Sales.扩容之前检查License是否支持节点数. 一.准备节点 提供节点并在每个节 ...

  5. 7. ClustrixDB 集群管理

    一. ALTER CLUSTER ADD (Flex Up):  添加节点以增加集群大小 添加节点过程: 步骤1.准备节点 提供节点并在每个节点上安装ClustrixDB,使用相同的版本和安装配置.如 ...

  6. 26. ClustrixDB 分布式架构/数据分片

    数据分片 介绍 共享磁盘vs.无共享 分布式数据库系统可分为两大类数据存储架构:(1)共享磁盘和(2)无共享. Shared Disk Architecture Shared Nothing Arch ...

  7. 21. ClustrixDB 识别平台限制

    本节描述集群性能上潜在的限制平台因素,如何度量集群是否接近或超过这些限制,以及纠正这些条件的可用选项.“平台因素”指的是硬件资源,如CPU.内存.磁盘和网络I/O子系统.有关潜在的软件相关因素,请参见 ...

  8. 18. ClustrixDB 管理CPU资源

    作为一个分布式MPP数据库,ClustrixDB能够利用多个节点和核心来比单节点数据库更快地处理查询.有两个可调进程可以促进这一点. Clustrix选择了一组默认参数来控制那些提供最常见工作负载的进 ...

  9. 15. ClustrixDB 管理数据分布

    本节使用的关键术语: Relation — ClustrixDB中的每个表都被称为“关系”. Representation — 在ClustrixDB中,每个索引都称为一个“Representatio ...

随机推荐

  1. 2 Java中常见集合

    1)说说常见的集合有哪些吧? 答:集合有两个基本接口:Collection 和 Map. Collection 接口的子接口有:List 接口.Set 接口和 Queue 接口: List 接口的实现 ...

  2. vue项目与node项目分离

    为了前后端分离,我们在前端和api层中间,架构了一层node层,用来做服务端渲染,来加快用户的首屏可用和对搜索引擎的友好.项目一开始放置在同一个git仓库里面,分别放在client目录和server目 ...

  3. 【神经网络与深度学习】【Matlab开发】caffe-windows使能Matlab2015b接口

    [神经网络与深度学习][Matlab开发]caffe-windows使能Matlab2015b接口 标签:[神经网络与深度学习] [Matlab开发] 主要是想全部来一次,所以使能了Matlab的接口 ...

  4. 【Angular5】 返回前一页面 go back to previous page

    import { Component, OnInit } from '@angular/core'; import { Router} from '@angular/router'; import { ...

  5. 【转帖】国产x86处理器KX-6000发布

    国产最先进x86处理器KX-6000发布:8核3.0GHz 力压酷睿i5处理器 https://www.cnbeta.com/articles/tech/858981.htm 全网所有的网页都写错了 ...

  6. Git介绍、安装、命令和实战

    一.Git介绍 Git是一个开源的分布式版本控制系统,可以有效.高速地处理从很小到非常大的项目版本管理. 二.Git安装(Mac系统) 在Git官网下载安装包双击直接安装 在终端输入git来检测Git ...

  7. python3爬取动态网站图片

    思路: 1.图片放在<image>XXX</image>标签中 2.利用fiddler抓包获取存放图片信息的js文件url 3.利用requests库获取html内容,然后获取 ...

  8. mysql在docker下运行,出现中文乱码

  9. CNN与图像高级应用

    一.图像识别与定位 思路1:视作回归 4个数字,用L2 loss/欧氏距离损失(x,y,w,h)这四个数都是连续值 思路2:借助图像窗口 二.物体识别 0.图像识别与定位: (1)Classifica ...

  10. 和IE6-IE8说拜拜 一段IE兼容HTML代码 针对IE版本写css

    通过这段html可以让你对特定的ie版本添加内容,只在特定版本ie展现,可以是javascript.css.html. <!--[if IE]> 这样使用IE浏览器(全部版本)的人都看得到 ...