读写分离概述
云数据库 MariaDB 默认支持读写分离能力,架构中的每个从机都能支持只读能力,如果配置有多个从机,将由网关集群(TProxy)自动分配到低负载从机上。
基于只读账号的读写分离
只读账号是一类仅有读权限的账号,默认从数据库集群中的从机(或只读实例)中读取数据。MariaDB 可以在 控制台 实例管理页的账号管理页中,设置只读账号和读策略:
在只读账号设置选项中,您可以设置只读请求分配策略,定义在备机故障(或延迟较大)时的读策略。只读备机延迟参数定义数据同步延迟时间,并与只读请求分配策略配合使用:选择主机则全部备机延迟时,从主机读取。
选择直接报错则全部备机延迟时,直接报错。
选择只从备机读取则忽略备机延迟,一直从备机读取(一般用于拉取 binlog 同步)。
只读备机延迟参数定义数据同步延迟时间。
分配策略 | 只读固定备机 | 不只读固定备机 |
主机 | 延迟后,若大于延迟参数,则切换到主机读取 | 延迟后,若大于延迟参数,则先读其他备机,其他备机延迟后切换到主机读取 |
直接报错 | 延迟后,若大于延迟参数,则直接报错 | 延迟后,若大于延迟参数,则先读其他备机,其他备机延迟后直接报错 |
只从备机读取 | 延迟后,只读固定备机 | - |
说明:
若需要修改只读账号设置,可以在账号列表,在操作列选择更多> 修改只读分配策略。
若您的实例架构为一主一从,只读分离功能仅可用作低负载只读任务,请避免大事务等较高负载任务,影响从机备份任务及可用性。
配置建议(例如您设计的是某交易系统):
核心交易模块:设置常规账号,可读写。
余额查询模块:设置只读账号,默认读备机;请求分配策略:备机故障读主机,并将延迟参数设置在十秒内,以保证主从性能和用户查询的数据一致性。
批量查询模块:设置只读账号,默认读备机;请求分配策略:备机故障报错,延迟参数可设置在三十秒以上,以保证不影响主库性能。
另外,由于强同步机制是将数据写入从机事务日志后,即返回应答,这时从机库表数据可能并未更新,因此也会有延迟。
基于注释的读写分离
通过如下视频,您可以了解基于注释的读写分离的使用:
在每条需要从机“读”的 SQL 前,增加
/*slave*/
字段,且 mysql 后面要增加 -c 参数来解析注释 mysql -c -e "/*slave*/sql"
,即可自动将读请求分配到从机,示例如下://主机读//select * from emp order by sal,deptno desc;//从机读///*slave*/ select * from emp order by sal,deptno desc;
注意
该功能仅支持从机读(select),不支持其他操作,非 select 语句将失败。
mysql 客户端需要增加 -c 参数来解析注释。
/*slave*/
必须为小写,语句前后无空格。从机出现异常而影响到 MAR(强同步)机制时,从机读操作将自动切换回主机。