我是靠谱客的博主 炙热酒窝,最近开发中收集的这篇文章主要介绍mysql8.0复制特性,MySQL8.0.22的新特性,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

MGR 具备了 RPO=0 的高可用容灾能力,但并不适合跨 WAN 场景下使用,像有两地三中心容灾需求的场景,单纯靠 MGR 是无法满足的,必须要拉上异步复制。

同城双中心距离在百十公里内,网络延迟可接受,要求 RPO=0,那么部署一组 MGR;

异地容灾中心距离在上百公里,网络延迟较大,接受 RPO>0,通过异步复制,部署单节点或对称部署一组 MGR。

在两地三中心架构下,如果同城双中心的集群主节点发生切换,异地容灾的节点并不能自动的跟随新的主节点继续同步。

Asynchronous Replication Automatic failover

其原理是在一条异步复制通道上配置多个可用复制源,当某个复制源不可用时(宕机、复制链路中断),且 slave 的 IO 线程尝试重连无效,自动根据权重选择新的源继续同步。

1. 准备一个 MGR 集群和单实例,模拟复制链路切换,当 primary 故障,slave 自动切换到其他节点。

dbdeployer deploy replication --topology=group 8.0.22 --single-primary

dbdeployer deploy single 8.0.22

2. 在从机上建立指向 MGR 主节点的复制通道,

change master to master_user='msandbox',

master_password='msandbox',

master_host='127.0.0.1',

master_auto_position=1,

source_connection_auto_failover=1,

master_port=23223,

master_retry_count=6,

master_connect_retry=10

for channel 'mgr-single';

在 master_retry_count 和 master_connect_retry 的设置上要考虑尝试重连多久才切换复制源。

3. 在从机上配置 asynchronous connection auto failover

配置 asynchronous connection auto failover 的两个函数:

asynchronous_connection_failover_add_source(channel-name,host,port,network-namespace,weight)

asynchronous_connection_failover_delete_source(channel-name,host,port,network-namespace)

权重值大的被优先级选择,可以配合MGR的选举权重配置 asynchronous_connection_failover 的权重。当 MGR 节点切换,异步复制也能切换到新的主节点。

SELECT asynchronous_connection_failover_add_source('mgr-single','127.0.0.1',23223,null,100);

SELECT asynchronous_connection_failover_add_source('mgr-single','127.0.0.1',23224,null,80);

SELECT asynchronous_connection_failover_add_source('mgr-single','127.0.0.1',23225,null,50);

start slave for channel 'mgr-single';

4. 检查异步复制通道是否启用 failover。

mysql> SELECT CHANNEL_NAME, SOURCE_CONNECTION_AUTO_FAILOVER FROM performance_schema.replication_connection_configuration;

-------------- ---------------------------------

| CHANNEL_NAME | SOURCE_CONNECTION_AUTO_FAILOVER |

-------------- ---------------------------------

| mgr-single | 1 |

-------------- ---------------------------------

1 row in set (0.01 sec)

5. 把 MGR 的 primary 节点 kill 掉,这个从节点会在尝试几轮重连失败后自动切换到次权重的复制源,其日志中会输出切换信息。

8626925b0ad45bc5bf8495af70ed7011.jpg

注意:当主节点故障,一旦复制链路成功 failover 后,在新的复制链路没有故障时,如果原主节点恢复,是不会回切的。如果当前复制链路发生故障,会再次选择权重高的进行切换。

声明:本网站所收集的部分公开资料来源于互联网,转载的目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。如果您发现网站上有侵犯您的知识产权的作品,请与我们取得联系,我们会及时修改或删除。导航:艺宵博客 » MySQL8.0.22的新特性

最后

以上就是炙热酒窝为你收集整理的mysql8.0复制特性,MySQL8.0.22的新特性的全部内容,希望文章能够帮你解决mysql8.0复制特性,MySQL8.0.22的新特性所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部