美文网首页
Changes in GreatSQL 5.7.36 (2022

Changes in GreatSQL 5.7.36 (2022

作者: GreatSQL | 来源:发表于2022-04-07 16:39 被阅读0次

[toc]

1.新增特性

1.2 新增MGR角色列

在MySQL 5.7中,查询 performance_schema.replication_group_members 时,没有 MEMBER_ROLE 这个列,这很不便于快速查看哪个节点是Primary Node。

在GreatSQL中,增加了这个列,查看节点角色更便利了,对一些中间件支持也更友好。

mysql> select * from performance_schema.replication_group_members;
+---------------------------+--------------------------------------+-------------+-------------+--------------+-------------+
| CHANNEL_NAME              | MEMBER_ID                            | MEMBER_HOST | MEMBER_PORT | MEMBER_STATE | MEMBER_ROLE |
+---------------------------+--------------------------------------+-------------+-------------+--------------+-------------+
| group_replication_applier | 4c21e81e-953f-11ec-98da-d08e7908bcb1 | 127.0.0.1   |        3308 | ONLINE       | SECONDARY   |
| group_replication_applier | b5e398ac-8e33-11ec-a6cd-d08e7908bcb1 | 127.0.0.1   |        3306 | ONLINE       | PRIMARY     |
| group_replication_applier | b61e7075-8e33-11ec-a5e3-d08e7908bcb1 | 127.0.0.1   |        3307 | ONLINE       | SECONDARY   |
+---------------------------+--------------------------------------+-------------+-------------+--------------+-------------+

1.2 采用全新的流控机制

原生的流控算法有较大缺陷,触发流控阈值后,会有短暂的流控停顿动作,之后继续放行事务,这会造成1秒的性能抖动,且没有真正起到持续流控的作用。

在GreatSQL中,重新设计了流控算法,增加主从延迟时间来计算流控阈值,并且同时考虑了大事务处理和主从节点的同步,流控粒度更细致,不会出现MySQL社区版本的1秒小抖动问题。

新增选项 group_replication_flow_control_replay_lag_behind 用于控制MGR主从节点复制延迟阈值,当MGR主从节点因为大事务等原因延迟超过阈值时,就会触发流控机制。

System Variable Name group_replication_flow_control_replay_lag_behind
Variable Scope global
Dynamic Variable YES
Permitted Values [0 ~ ULONG_MAX]
Default 600
Description 单位:秒。
用于控制MGR主从节点复制延迟阈值,当MGR主从节点因为大事务等原因延迟超过阈值时,就会触发流控机制

该选项默认为600秒,可在线动态修改,例如:

mysql> SET GLOBAL group_replication_flow_control_replay_lag_behind = 600;

正常情况下,该参数无需调整。

1.3 新增MGR网络开销阈值

新增相应选项 group_replication_request_time_threshold

在MGR结构中,一个事务的开销包含网络层以及本地资源(例如CPU、磁盘I/O等)开销,GreatSQL针对MGR的网络层开销进行了多项优化工作,因此在网络层的开销通常不会成为瓶颈。

当事务响应较慢想要分析性能瓶颈时,可以先确定是网络层的开销还是本地性能瓶颈导致的。通过设置选项 group_replication_request_time_threshold 即可记录超过阈值的事件,便于进一步分析。输出的内容记录在error log中,例如:

2022-03-04T09:45:34.602093+08:00 128 [Note] Plugin group_replication reported: 'MGR request time:33775'

表示当时这个事务在MGR层的网络开销耗时33.775毫秒,再去查看那个时段的网络监控,分析网络延迟较大的原因。

选项 group_replication_request_time_threshold 单位是微秒,默认值是0,最小值0,最大值100000000,建议值20000(即20毫秒)。

System Variable Name group_replication_request_time_threshold
Variable Scope Global
Dynamic Variable YES
Permitted Values [0 ~ 100000000]
Default 0
Description 单位:微秒。
设置阈值,当一个事务的MGR层网络开销超过该阈值时,会在error log中输出一条记录。
设置为0时,表示不启用。
当怀疑可能因为MGR通信耗时过久成为事务性能瓶颈时,再开启,平时不建议开启。

1.4 调整MGR大事务限制

调整MGR事务限制选项 group_replication_transaction_size_limit,其默认值为150000000(同时也是最大值)。

在MySQL 5.7中,MGR事务没有进行分片处理,执行大事务很容易造成超时(并反复重发事务数据),最终导致节点报错并退出集群。

在GreatSQL 5.7中,针对该问题进行优化,并设置事务上限,超过该上限事务会失败回滚,但节点不会再退出集群。

注意,这是硬限制,即便将其设置为0,也会自动调整成150000000。

mysql> set global group_replication_transaction_size_limit = 150000001;
Query OK, 0 rows affected, 1 warning (0.00 sec)

-- 提示被重置了
mysql> show warnings;
+---------+------+-------------------------------------------------------------------------+
| Level   | Code | Message                                                                 |
+---------+------+-------------------------------------------------------------------------+
| Warning | 1292 | Truncated incorrect group_replication_transaction_si value: '150000001' |
+---------+------+-------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> set global group_replication_transaction_size_limit=0;
Query OK, 0 rows affected (0.00 sec)

-- 虽然没有error也没warning,但也被重置了
mysql> select @@global.group_replication_transaction_size_limit;
+---------------------------------------------------+
| @@global.group_replication_transaction_size_limit |
+---------------------------------------------------+
|                                         150000000 |
+---------------------------------------------------+

当执行一个超限的大事务时,会报告下面的错误:

ERROR 3100 (HY000): Error on observer while running replication hook 'before_commit'.

以测试工具sysbench生成的表为例,事务一次可批量执行的数据行上限约73.2万条记录:

mysql> insert into t1 select * from sbtest1 limit 732000;
Query OK, 732000 rows affected (16.07 sec)
Records: 732000  Duplicates: 0  Warnings: 0

mysql> insert into t1 select * from sbtest1limit 733000;
ERROR 3100 (HY000): Error on observer while running replication hook 'before_commit'.

如果大事务能执行成功,也会记录类似下面的日志,告知该事务的字节数:

[Note] Plugin group_replication reported: 'large transaction size:149856412'
System Variable Name group_replication_transaction_size_limit
Variable Scope Global
Dynamic Variable YES
Permitted Values [0 ~ 150000000]
Default 150000000
Description 单位:Bytes。
设置大事务阈值,当一个MGR事务超过该阈值时,会在error log中输出一条记录

2.稳定性提升

  1. 修复了在异常情况下(节点崩溃,关闭节点,网络分区)的剧烈性能抖动问题。
  2. 提升数个大事务造成的长时间阻塞的问题。

3.性能提升

  1. 重新设计事务认证队列清理算法。MySQL社区版本中,对事务认证队列清理时采用了类似全表扫描的算法,清理效率较低,性能抖动较大。在GreatSQL版本中,对事务认证队列增加了类似索引机制,并控制每次清理的时间,可以有效解决清理效率低、性能抖动大的问题。
  2. 提升了Secondary节点上大事务并发应用回放的速度。
  3. 增加xcom cache条目,提升了在网络延迟较大或事务应用较慢场景下的性能。

4.bug修复

  1. 修复了在启用dns或hostname的情况下,bind意外失败问题。
  2. 修复了协程调度不合理的问题,该问题可能会造成在大事务时系统错误判断为网络错误。
  3. 修复了新加入节点在追paxos数据时,由于write超时导致连接提前关闭的问题。
  4. 修复了recovering节点被中途停止导致的数据异常问题。
  5. 修复了多主多写模式中,个别情况下可能丢数据的问题。
  6. 修复了在某些特殊场景下,多个节点同时启动一直处于recovering的状态
  7. 修复了applier线程在特殊场景下的诡异问题。
  8. 修复了在高并发情况下由于创建线程失败导致的死循环问题。
  9. 修复了某一个从节点hang住导致整个集群被拖垮的问题。
  10. 修复了单机部署多个节点场景下,tcp self connect导致的诡异问题。
  11. 修复了同时多个异常导致的视图问题。
  12. 修复了5个及以上节点数量同时重启导致的视图问题(某一个节点会一直处于recovering状态)。
  13. 修复了在某些场景下同时添加节点失败的问题。
  14. 修复了在特殊场景下组视图异常的问题。

Enjoy GreatSQL :)

本文由博客一文多发平台 OpenWrite 发布!

相关文章

  • Changes in GreatSQL 5.7.36 (2022

    [toc] 1.新增特性 1.2 新增MGR角色列 在MySQL 5.7中,查询 performance_sche...

  • Changes in GreatSQL 8.0.25-16(20

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。 [toc] 1.新增特性 1.1 新...

  • GreatSQL FAQ

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。 [toc] 关于GreatSQL及M...

  • docker部署PXC5.7

    下載pxc5.7.36docker pull percona/percona-xtradb-cluster:5.7...

  • lucky记录629天

    2022年10月16日扇贝每日一句 2023年倒计时76天 None of us really changes o...

  • 《Kaplan GMAT 800》 语法部分笔记

    综述信息 Unnecessary changes are incorrect changes when it co...

  • 仁爱版 九年级上册英语周报作文14篇

    一:Great changes in my hometown These years, great changes...

  • 01-centeros7安装mysql5.7

    1 安装MySQL 1.1 下载对应文件 mysql-5.7.36-1.el7.x86_64.rpm-bundle...

  • Changes

    我想,我是时候做出一些改变了,不需要多大,不需要多让人惊讶,只是让自己遇见更美好的自己,坚持晚上刷牙第一天,坚持早...

  • Changes

    世界在以肉眼可见的速度变化。 10年前没有android、也没有iOS,诺基亚还在巅峰。为了给朋友弄到一台手机,我...

网友评论

      本文标题:Changes in GreatSQL 5.7.36 (2022

      本文链接:https://www.haomeiwen.com/subject/ookssrtx.html