Redis主备实例
本章节主要介绍Redis缓存类型的主备实例。
不支持Redis版本的升级,例如,不支持Redis 4.0主备升级为Redis 5.0主备实例。如果需要使用高版本Redis主备实例,建议重新创建高版本Redis主备实例,然后将原有Redis实例的数据迁移到高版本实例上。
主备实例特点
DCS的主备实例在单机实例基础上,增强服务高可用以及数据高可靠性。
主备实例具有以下特性:
- 持久化,确保数据高可靠
实例包含一个主节点和一个备节点,都默认开启数据持久化。
Redis 3.0主备实例的备节点对用户不可见,不支持客户端直接读写数据。
Redis 4.0及以上版本的基础版主备实例的备节点对用户可见,用户可以通过只读地址连接到备节点上读取数据。
- 数据同步
主备节点通过增量数据同步的方式保持缓存数据一致。
当网络发生异常或有节点故障时,主备实例会在故障恢复后进行一次全量同步,保持数据一致性。
- 故障后自动切换主节点,服务高可用
当主节点故障后,连接会有秒级中断、不可用,备节点在15秒到30秒内自动完成主备切换,切换完成后恢复正常访问,无需用户操作,保证业务平稳运行。
- 故障切换期间,会有连接中断和不可用等情况,需要业务侧客户端具备重连/重试机制。
- 主备切换完成后,原主节点(已切换为从节点)因故障不会立刻恢复,业务继续访问原主节点会失败,可通过配置Redis SDK解决此类情况,具体请参见使用客户端连接Redis。
- 多种容灾策略
跨AZ部署(可用区):DCS支持将主备实例的主备副本部署在不同的AZ内,节点间电力与网络均物理隔离。您可以将应用程序也进行跨AZ部署,从而达到数据与应用全部高可用。
- 读写分离
Redis 4.0、Redis 5.0和Redis 6.0基础版主备实例支持客户端读写分离,分别提供可读写的连接地址(主节点)和只读地址(备节点),客户端连接时,可分别选择主节点或备节点。
主备实例实现客户端读写分离,需要在客户端做配置。如需使用读写分离功能,推荐使用读写分离实例。
Redis 3.0主备实例架构设计
DCS的Redis 3.0主备实例架构,如图1所示。
示意图说明:
- VPC
虚拟私有云。实例的内部所有服务器节点,都运行在相同VPC中。
- 客户应用
运行在ECS上的客户应用程序,即Redis的客户端。
Redis实例兼容开源协议,可直接使用开源客户端进行连接,关于多语言客户端连接示例,请参考用户指南的连接缓存实例。
- DCS缓存实例
DCS实例。主备实例包含了Master和Replica两个节点。默认开启数据持久化功能,同时保持节点间数据同步。
DCS实时探测实例可用性,当主节点故障后,备节点升级为主节点,恢复业务。
Redis的访问端口默认为6379。
Redis 4.0/5.0/6.0基础版主备实例架构设计
Redis 4.0/5.0/6.0基础版主备实例的架构设计,如下图所示。
图说明如下:
- Redis 4.0/5.0/6.0基础版主备实例,分别提供可读写的域名连接地址(用于连接主节点)和只读地址(用于连接备节点)。
- Redis 4.0/5.0/6.0基础版主备实例使用哨兵模式(Sentinel)进行管理,Sentinel会一直监控主备节点是否正常运行,当主节点出现故障时,进行主备倒换。
Sentinel对用户不可见,仅在服务内部中使用。Sentinel的详细介绍可参考什么是哨兵。
- 只读节点和读写节点规格一致,用户创建主备实例时,默认包含一个主节点和一个备节点。
- Redis 4.0及以上版本的基础版实例支持定义端口,如果不自定义端口,则使用默认端口6379。图中以默认端口6379为例,如果已自定义端口,请根据实际情况替换。
- Redis 4.0及以上版本的基础版主备实例在只读域名不带负载均衡,对于可靠性和时延敏感的应用场景,建议使用集群或读写分离类型的实例。
- Redis 4.0及以上版本的基础版主备实例的只读域名在从节点发生故障场景下会出现请求失败的情况,对于可靠性和时延敏感的应用场景,建议使用读写分离类型的实例。
Redis 6.0企业版主备实例架构设计
Redis 6.0企业版主备实例架构设计如图3所示。
- VPC
虚拟私有云。实例的内部所有服务器节点,都运行在相同VPC中。
VPC内访问,客户端需要与Redis 6.0企业版主备实例处于相同VPC,并且配置安全组访问规则。配置方式请参考如何选择和配置Redis实例以及客户端的安全组。
- 客户应用
运行在ECS上的客户应用程序,即Redis的客户端。
Redis实例兼容开源协议,可直接使用开源客户端进行连接,关于多语言客户端连接示例,请参考使用客户端连接Redis。
- DCS缓存实例
DCS实例。主备实例包含了Master和Replica两个节点。
Redis 6.0企业版主备实例使用哨兵模式(Sentinel)进行管理,Sentinel会一直监控主备节点是否正常运行,当主节点出现故障时,进行主备倒换。
Sentinel对用户不可见,仅在服务内部中使用。Sentinel的详细介绍可参考什么是哨兵。
Redis的访问端口默认为6379。