DRDS读写分离功能可以将只读查询的流量按比例分摊至下挂存储节点的主实例和只读实例,从而减轻主实例的工作负担,保障读写事务的性能。此功能对应用透明,业务代码无需改造,只需要在控制台上设置主实例和只读实例的读权重,即可实现将读流量按照权重分流到主实例和只读实例上,写流量不受影响,默认会分流到主实例上。一般来说该比例的设置需结合业务实际特点以及存储节点实际负载进行设置。
只读实例上的数据是从主实例上异步复制而来,所以存在毫秒级的延迟。如果只读查询对数据实时性要求不高(容忍亚秒级可见性延迟)且只读查询的开销较大并对业务核心读写事务有一定影响,设置主实例和只读实例的权重为0:100,即所有只读查询均由只读实例承担,最大程度保证主实例性能。对于其他场景,建议结合实际情况酌情调整。
使用须知
-
DRDS内核版本大于等于3.1.0版本时,需要手动开启读写分离,然后调整只读实例和主实例的读写权重来实现读写分离操作。
-
如果DRDS内核版本小于3.1.0版本,系统默认开启读写分离,只需要调整只读实例和主实例的读写权重即可以实现读写分离操作。
-
若select语句带有hint或者在事务中做了数据修改的select语句,读请求都会下发主实例执行。
-
如果存储节点主实例故障,此时只读实例上Seconds_Behind_Master=NULL,只读查询仍会下发到主实例执行,需要尽快恢复主实例。
前提条件
- 已申请DRDS实例和带只读实例的数据节点。
- 已经创建好逻辑库。
操作步骤
1、登录分布式关系型数据库控制台。
2、单击目标实例名称,进入实例基本信息页面。
3、在左侧导航栏,单击“DN管理”页签。
4、开启读写分离。
5、设置读写权重。