推荐使用更新的引擎版本以支持更多的特性。

Redis 6.0新特性说明:

  • 模块系统新增多个API。

  • 支持SSL/TLS加密。

  • 支持新的Redis协议:RESP3。

  • 服务端支持多模式的客户端缓存。

  • 支持多线程IO。

  • 副本中支持无盘复制(diskless replication)。

  • Redis-benchmark新增了Redis集群模式。

  • 支持重写Systemd。

  • 支持Disque模块。

Redis 5.0新特性说明

  • 云数据库Redis 5.0版本大幅度优化内核,运行更加稳定,同时新增Stream、账号管理、审计日志等多种特性,满足您更多场景下的使用需求。

  • 新的数据类型:流数据(Stream)。详细说明请参见Redis Streams。

  • 新增账号管理功能。

  • 新增日志管理功能,支持审计日志、运行日志和慢日志,您可以通过日志管理查询读写操作、敏感操作(如KEYS、FLUSHALL)和管理类命令的使用记录以及慢日志。

  • 新增基于快照的缓存分析功能。

  • 新的定时器(Timers)、集群( Cluster)和字典(Dictionary)模块的API。

  • RDB中增加LFU和LRU信息。

  • 集群管理器从Ruby (redis-trib.rb)移植到了redis-cli中的C语言代码。

  • 新增有序集合(Sorted Set)命令ZPOPMIN、ZPOPMAX、BZPOPMIN和BZPOPMAX。

  • 升级Active Defragmentation至v2版本。

  • 增强HyperLogLog的实现。

  • 优化内存统计报告。

  • 为许多有子命令的命令增加了HELP子命令。

  • 提高了客户端频繁连接和断开连接时的性能表现。

  • 升级Jemalloc至5.1版本。

  • 新增命令CLIENT ID和CLIENT UNBLOCK。

  • 新增了为艺术而生的LOLWUT命令。

  • 弃用slave术语(需要API向后兼容的情况例外)。

  • 对网络层进行了多处优化。

  • 进行了一些Lua相关的改进。

  • 新增动态HZ(Dynamic HZ)以平衡空闲CPU使用率和响应性。

  • 对Redis核心代码进行了重构并在许多方面进行了改进。

-     架构    -

您需要根据业务需求选择:

  • 集群架构可轻松突破Redis自身单线程瓶颈,满足大容量、高性能的业务需求。

  • 主从架构,提供高性能的缓存服务和数据高可靠。

  • 读写分离架构提供高可用、高性能、高灵活的读写分离服务,解决热点数据集中及高并发读取的业务需求,最大化地节约用户运维成本。

2.1 主从架构-双副本

采用主从(master-replica)模式搭建。主节点提供日常服务访问,备节点提供HA高可用,当主节点发生故障,系统会自动在30秒内切换至备节点,保证业务平稳运行。

-     可靠性    -

  • 服务可靠采用双机主从(master-replica)架构,主从节点位于不同物理机。

    主节点对外提供访问,用户可通过Redis命令行和通用客户端进行数据的增删改查操作。

    当主节点出现故障,HA系统会自动进行主从切换,保证业务平稳运行。

  • 数据可靠默认开启数据持久化功能,数据全部落盘。

    支持数据备份功能,用户可以针对备份集回滚实例或者克隆实例,有效地解决数据误操作等问题。

-     使用场景    -

  • Redis作为持久化数据存储使用的业务标准版提供持久化机制及备份恢复机制,极大地保证数据可靠性。

  • 单个Redis性能压力可控的业务由于Redis原生采用单线程机制,性能在10万QPS以下的业务建议使用。

    如果需要更高的性能要求,请选用集群版本。

  • Redis命令相对简单,排序、计算类命令较少的业务由于Redis的单线程机制,CPU会成为主要瓶颈。

    如排序、计算类较多的业务建议选用集群版配置。

2.2 主从架构-单副本

可以在没有数据可靠性要求的纯缓存场景充分发挥性能优势。

使用场景

  • 纯缓存类业务场景

单副本版本只有一个数据库节点,节点出现故障时,系统会重新拉起一个Redis进程(没有数据),当节点故障业务自动切换完成后,应用程序需要将数据重新预热,以免对后端数据库产生访问压力冲击。

单副本架构不能提供数据可靠性,如果发生节点故障,您需要重新对业务进行预热,因此,在对数据可靠性要求较高的敏感性业务中,建议选用双副本架构。

  • 单个Redis性能压力可控

由于Redis原生采用单线程机制,CPU为单核能力,性能在8万QPS的业务建议使用。如果需要更高的性能要求,请选用集群版配置。

  • Redis命令相对简单,排序、计算类命令较少

由于Redis的单线程机制,CPU为主要瓶颈。如排序、计算类较多的业务建议选用集群版配置。

2.3 集群版-双副本

可轻松突破Redis自身单线程瓶颈,满足大容量、高性能的业务需求。双副本集群版实例采用集群架构,每个分片服务器采用主从(master-replica)双副本模式。集群版支持代理和直连两种连接模式,您可以根据本章节的说明,选择适合业务需求的连接模式。

-     代理模式    -

集群架构的本地盘实例默认采用代理(proxy)模式,支持通过一个统一的连接地址(域名)访问Redis集群,客户端的请求通过代理服务器转发到各数据分片,代理服务器、数据分片和配置服务器均不提供单独的连接地址,降低了应用开发难度和代码复杂度。代理模式的服务架构图和组件说明如下。

直连模式

因所有请求都要通过代理服务器转发,代理模式在降低业务开发难度的同时也会小幅度影响Redis服务的响应速度。

如果业务对响应速度的要求非常高,您可以使用直连模式,绕过代理服务器直接连接后端数据分片,从而降低网络开销和服务响应时间。直连模式的服务架构和说明如下。

前提条件 使用Jedis、PhpRedis等支持Redis Cluster的客户端。

  • 使用不支持Redis Cluster的客户端,可能因客户端无法重定向请求到正确的分片而获取不到需要的数据。

  • Jedis对于Redis Cluster的支持是基于JedisCluster这个类,详细说明请参见Jedis文档。

  • 您可以在Redis官网的客户端列表里查找更多支持Redis Cluster的客户端。

使用自定义连接池的示例代码 :

import redis.clients.jedis.*;
import java.util.HashSet;
import java.util.Set;
public class main {
private static final int DEFAULT_TIMEOUT = 2000;
private static final int DEFAULT_REDIRECTIONS = 5;
private static final JedisPoolConfig DEFAULT_CONFIG = new JedisPoolConfig();public static void main(String args[]){JedisPoolConfig config = new JedisPoolConfig();// 最大空闲连接数, 根据业务需要设置,不能超过实例规格规定的最大的连接数config.setMaxIdle(200);// 最大连接数, 根据业务需要设置,不能超过实例规格规定的最大的连接数config.setMaxTotal(300);config.setTestOnBorrow(false);config.setTestOnReturn(false);// 开通直连访问时申请到的直连地址String host = "r-bp1xxxxxxxxxxxx.redis.rds.aliyuncs.com"; int port = 6379;// 实例的密码String password = "xxxxx";Set<HostAndPort> jedisClusterNode = new HashSet<HostAndPort>();jedisClusterNode.add(new HostAndPort(host, port));JedisCluster jc = new JedisCluster(jedisClusterNode, DEFAULT_TIMEOUT, DEFAULT_TIMEOUT,DEFAULT_REDIRECTIONS,password, "clientName", config);
}
}

2.4 集群版-单副本

2.5 读写分离版

针对读多写少的业务场景,提供高可用、高性能、灵活的读写分离服务,满足热点数据集中及高并发读取的业务需求,最大化地节约运维成本。读写分离版主要由主备节点、只读节点、Proxy(代理)节点和高可用系统组成。

-     特点    -

特点

  • 高可用

  1. 通过自研的高可用系统自动监控所有数据节点的健康状态,为整个实例的可用性保驾护航。

    主节点不可用时自动选择新的主节点并重新搭建复制拓扑。

    某个只读节点异常时,高可用系统能够自动探知并重新启动新节点完成数据同步,下线异常节点。

  2. Proxy节点实时感知每个只读实例的服务状态。

    在某个只读实例异常期间,Proxy会自动降低该节点的服务权重,发现只读节点连续失败超过一定次数以后,会停止异常节点的服务权利,并具备继续监控后续重新启动节点服务的能力。

  • 高性能

  1. 读写分离版采取链式复制架构,可以通过扩展只读实例个数使整体实例性能呈线性增长,同时基于源码层面对Redis复制流程的定制优化,可以最大程度地提升线性复制的系统稳定性,充分利用每一个只读节点的物理资源。

-     使用场景    -

  • 读取请求QPS(Queries Per Second)压力较大

标准版Redis无法支撑较大的QPS,如果业务类型是读多写少类型,需要采用多个只读节点的部署方式来突破Redis单线程的性能瓶颈。Redis集群版提供1个、3个、5个只读节点的配置,相比标准版可以将QPS提升近5倍。

对Redis协议兼容性要求较高的业务 读写分离版完全兼容Redis协议命令,可将自建Redis数据库迁移至读写分离版,同时支持从Redis标准版(双副本)一键平滑升级至读写分离版。

-     总结    -

  • 当一个只读节点发生故障时,请求会转发到其他节点;如果所有只读节点均不可用,请求会全部转发到主节点。只读节点异常可能导致主节点负载提高、响应时间变长,因此在读负载高的业务场景建议使用多个只读节点。

  • 某些场景会触发只读节点的全量同步,例如在主节点触发高可用切换后。全量同步期间只读节点不提供服务并返回-LOADING Redis is loading the dataset in memory\r\n信息。

热门内容:求你别再用swagger了,给你推荐几个在线文档生成神器IntelliJ IDEA官方宣布中文汉化包正式发布低代码 yyds再见Spring!下一个开源框架更香!最近面试BAT,整理一份面试资料《Java面试BAT通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。获取方式:点“在看”,关注公众号并回复 666 领取,更多内容陆续奉上。

明天见(。・ω・。)ノ♡

Redis生产环境架构选型方案对比相关推荐

  1. T31项目架构选型方案

    服务选型 曾经的技术选型 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GjyeLuSg-1636378253985)(C:\Users\Zyf\Desktop\T31 ...

  2. java技术架构选型方案报告.pdf,技术架构选型方案报告

    <技术架构选型方案报告>由会员分享,可在线阅读,更多相关<技术架构选型方案报告(16页珍藏版)>请在人人文库网上搜索. 1.最高院执行项目 技术架构选型方案 Fantasy 2 ...

  3. redis生产环境持久化_在SageMaker上安装持久性Julia环境

    redis生产环境持久化 SageMaker is a great environment for data scientists to explore new languages and metho ...

  4. Kubernetes — 生产环境架构简述

    目录 文章目录 目录 Kubernetes 在生产环境中架构 基础设施层 业务应用层 服务访问层 Kubernetes 在生产环境中架构 Client 层:即外部用户.客户端等: 服务访问层:即由 T ...

  5. Mysql生产环境表更新方案_生产环境中,数据库升级维护的最佳解决方案flyway

    官网:https://flywaydb.org/ 转载:http://casheen.iteye.com/blog/1749916 1.  引言 想到要管理数据库的版本,是在实际产品中遇到问题后想到的 ...

  6. Redis生产环境你还敢用keys?我劝你放下屠刀,回头是岸!

    来源:my.oschina.net/xiaolyuh/blog/3169203 SCAN 命令及其相关的 SSCAN 命令. HSCAN 命令和 ZSCAN 命令都用于增量地迭代(incrementa ...

  7. redis生产环境下部署lua脚本

    加载到redis redis-cli script load "$(cat test.lua)" 得到sha1值 执行 redis-cli evalsha "7a2054 ...

  8. redis生产环境中慎用keys模糊匹配方法

    Redis是一个key-value存储系统.和Memcached类似,但性能远高于memcached.现在很多大型互联网公司都在使用redis作为自己的缓存实现,但是如果没有合理使用好redis,比如 ...

  9. mysql生产环境运维方案_[MySQL生产环境] Innodb存储引擎内存报警问题处理过程

    1 不停的收到email报警,内存值超过阀值80%了. 2 top下,mysqld进程确实占据了77.5%,再加上一些其他的辅助进程,内存usage到了81%也可以理解. [xxx@00903 5.5 ...

最新文章

  1. 2021年大数据ELK(二十四):安装Kibana
  2. 客户端负载均衡Ribbon之一:Spring Cloud Netflix负载均衡组件Ribbon介绍
  3. 如何kill掉tomcat服务
  4. Spring MVC-08循序渐进之国际化(AcceptHeaderLocaleResolver)
  5. Javascript实现导航锚点滚动效果实例
  6. window系统下C语言找不到fork()函数
  7. Angular依赖注入的一个例子和注入原理单步调试
  8. 使用Visual Studio Code配合TypeScript增强SAP UI5开发的语法检查
  9. Poj3261 Milk Patterns
  10. Confluence 6 手动备份站点
  11. Java8 函数式对齐约定————Eclipse自定义代码风格
  12. thinkphp5 memcached 安装、调用、链接
  13. python测量镜头到目标距离_摄像头单目测距原理及实现
  14. webpack中hash、chunkhash、contenthash
  15. mysql C where语句_MYSQL WHERE语句优化
  16. python中dump与dumps的区别
  17. Linux下的目录简介
  18. 蓝奏云无视密码强制下载器
  19. mysql配置文件路径
  20. python 流水作业调度,流水作业调度完整代码

热门文章

  1. redhat linux系统补丁,如何在CentOS和RHEL系统上安装或自动更新安全补丁
  2. 人工神经网络:感知器
  3. 测试用例设计方法基础理论知识
  4. 单页面与多页面的区别及优缺点
  5. GitLab 配置邮箱
  6. Storm Trident示例function, filter, projection
  7. go1.8之安装配置
  8. EasyPusher实现Android手机屏幕桌面直播,实时推送操作画面,用于手游直播等应用
  9. TCP/IP 笔记 1.3 IP:网际协议
  10. 【NCEPU】王子朝:神经网络、支持向量机原理