MySQL运维实战之ProxySQL(9.4)proxysql和后端MySQL自动切换

俊达2年前技术文章1302

ha.png


如上图架构,当后端MySQL主库出现问题,发生主备切换后,如何自动将ProxySQL的读写切换到新的主库上?


可以通过mysql_replication_hostgroups表配置实现:

insert into mysql_replication_hostgroups
(writer_hostgroup, reader_hostgroup, check_type, comment)
values(100, 101, 'read_only', 'mysql mm cluster');

load mysql servers to runtime;
save mysql servers to disk;


将主库和备库的hostgroup配置到mysql_replication_hostgroups表中后,proxysql会检测主备库的read_only状态。

当检测到read_only从OFF变成ON时,会将writer_hostgroup中的主机添加的reader_hostgrup中。

当检测到read_only从ON变成OFF时,会将主机从reader_hostgroup中移到writer_hostgroup中。


当一个后端mysql实例的read_only状态从ON变成OFF时,会将该实例加入到writer_hostgroup中,同时该实例依然位于read_hostgroup中:

mysql> select hostgroup_id, hostname, port , status from runtime_mysql_servers where hostgroup_id in (100,101);
+--------------+----------------+------+--------+
| hostgroup_id | hostname       | port | status |
+--------------+----------------+------+--------+
| 100          | 172.16.121.237 | 3380 | ONLINE |
| 101          | 172.16.121.236 | 3380 | ONLINE |
| 101          | 172.16.121.237 | 3380 | ONLINE |
+--------------+----------------+------+--------+


可以看到,节点172.16.121.237:3380 同时位于两个hostgroup。


如果需要将该实例从read hostgroup中移除,需要将参数mysql-monitor_writer_is_also_reader设置为false:

set mysql-monitor_writer_is_also_reader='false';
load mysql variables to runtime;

然后再重新加载mysql server,就可以将设置了read_only状态的后端实例从read hostgroup中移除。

mysql> load mysql servers to runtime;
Query OK, 0 rows affected (0.00 sec)

mysql> select hostgroup_id, hostname, port , status from runtime_mysql_servers where hostgroup_id in (100,101);
+--------------+----------------+------+--------+
| hostgroup_id | hostname       | port | status |
+--------------+----------------+------+--------+
| 100          | 172.16.121.237 | 3380 | ONLINE |
| 101          | 172.16.121.236 | 3380 | ONLINE |
+--------------+----------------+------+--------+
2 rows in set (0.00 sec)


proxysql只根据后端mysql的read_only状态来判断将实例放到write hostgroup或read hostgroup。所以需要正确地设置read_only状态。

  • 如果主备实例都设置了read_only=OFF,则会发生双写,容易引起数据不一致。

  • 如果在备库复制有延迟或备库复制中断的情况下,将备库的read only设置为OFF,同样也可能会引起数据不一致。

  • 后端MySQL实例的高可用,需要借助其它方式来实现,如MHA。或者使用MySQL Group Replication。



相关文章

MySQL优化器特性(五)单表访问路径

数据库的访问路径(access path)是指从表中获取数据的方式,一般可以通过扫描表或通过索引获取数据。想熟练掌握SQL优化技能,首先需要熟悉单表访问路径。本文先简单介绍MySQL支持的各种单表访问...

MySQL运维实战(3.2) 常见数据库连接失败问题排查

如果数据库连接失败,可以从如下几方面来排查:1、客户端到服务端的网络是否畅通,服务端端口是否能连通。使用ping、telnet等工具探测服务端的端口是否能访问。[root@box3 ~]#&...

MySQL运维实战之备份和恢复(8.3)xtrabackup增量备份

xtrabackup支持增量备份。在做增量备份之前,需要先做一个全量备份。xtrabackup会基于innodb page的lsn号来判断是否需要备份一个page。如果page lsn大于上次备份的l...

MySQL运维实战(5.5) 数据导入导出时的字符集问题

mysql可以使用load data/select into outfile或mysqldump工具进行数据导入导出。下面分别分析数据导入导出时的字符集相关问题。准备测试数据创建测试表,2个字段分别使...

MySQL运维实战(4.8) SQL_MODE之NO_ENGINE_SUBSTITUTION

开启NO_ENGINE_SUBSTITUTION,建表时如果指定的存储引擎不可用或不存在,SQL报错。否则会使用默认的存储引擎替换。如果不设置NO_ENGINE_SUBSTITUTION,建表时指定的...

MySQL运维实战之Clone插件(10.2)Clone插件原理

MySQL运维实战之Clone插件(10.2)Clone插件原理

clone插件实现clone操作主要分为几个阶段:1、初始阶段。初始阶段,会开启页面跟踪(Page Tracking)。开启页面跟踪后,修改过的页面的编号会被记录下来。页面的修改可分为两个阶段:首先在...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。