Redis实践(5)Cluster模式高可用架构

Redis的高可用架构包含主从复制、Sentinel哨兵和Cluster机制,而在前文中大量的实践了主从模式的高可用架构下的相关实现,也讲述到了这种模式的几个劣势,所以基于主从复制架构响应的实现告一段落了,而哨兵模式的高可用方案在前几年初期学习Redis时认为太过复杂,学习难度较大,所以本批次的实践将跳过哨兵模式,直接拥抱更科学的Cluster模式,前文提出的主从架构模式劣势参考如下: (1)所有从机的数据依赖主机节点,主节点不能宕机,否则主节点数据的写入将不可用,从节点的读取尚可,可用性较低; (2)主节点的写入压力仍然存在,从节点为只读模式无法分担写入压力; 1.哨兵(Sentinel)模式 Redis Sentinel 的高可用性是非集群Redis的高可用,Redis Sentinel 在不使用Redis Cluster时为 Redis 提供高可用性。Redis Sentinel 还...

文章分类:经验分享 技术知识

Redis

Redis实践(4.6)SpringBoot 测试主从数据序列化

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中使用RedisTemplate操作redis相关的API,实现数据存储和读取的序列化实现,前文的工具类提供了基于StringRedisTemplate和RedisTemplate的两种实现,仔细一些会发现《Redis实践(4.5)SpringBoot 测试数据类型读写》中涉及的数据类型多数为简单的字符串类型,虽然任何数据类型在存储时都可以使用String类型存储,取出来自己在用JSON来解析进行类型二次转换,但是这种实现让人感觉到不够优雅,所以本文主要就是基于List<User>结构的数据类型进行序列化,关注对象类型数据的存储和获取的优雅程度,详见下文。 1.Bo定义 /** *定义User对象,使用多种数据类型 */ publicstaticclassUser{ pri...

文章分类:经验分享 技术知识

Redis

Redis实践(4.5)SpringBoot 测试主从数据类型读写

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中使用RedisTemplate操作redis相关的API,实现不同数据类型的写入和读取,涉及到string、list、set、zset、hash、geo、stream等多种数据类型,虽然类型较多且复杂多样,个人学习实践也仅属于蜻蜓点水的粗略掌握程度,详见下文。 1.string /** *字符串的存取 */ @Test publicvoidstring(){ System.out.println("两种方式存取,应使用StringRedisTemplate"); this.writeRedisTemplate.boundValueOps("name").set("陈冬冬-"+getDatetime()); Stringname1=(String)this.readRedi...

文章分类:经验分享 技术知识

Redis

Redis实践(4.4)SpringBoot 测试主从读写分离

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中使用自定义的工具类操作redis相关的API,实现操作Redis读模式的负载均衡。本篇文章则来实践一下在常规应用中的读写分离,如果是在项目中原始集成的话,跟数据库的读写分离一样,用两套数据源,分别指向读库可写库来实现,详见下文。 1.参考代码 packagecn.chendd.redis; /** *Redis读写分离测试 *@authorchendd *@date2023/5/2022:00 */ publicclassRedisWriteReadTestextendsBaseTest{ /** *写客户端 */ @Resource(name=RedisConstants.WRITE_STRING_REDIS_TEMPLATE) privateStringRedi...

文章分类:经验分享 技术知识

Redis

Redis实践(4.3)SpringBoot 读模式的负载均衡

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中使用自定义的工具类操作redis相关的API,实现操作Redis读模式的负载均衡。前篇示例中分别提供了注解@Resource注入的形式获取RedisTemplate类型,但是获取到固定的是某台服务器的连接模板对象,在使用过程中一旦定义则每次请求均来自一个模块,理论上可以通过模块功能代码的形式来实现压力复杂。另外一种则是本文使用的工具类来实现读取数据的负载均衡(前文中所述写模式只有一台服务器所以不存在负载均衡),详见下文。 1.RedisUtils packagecn.chendd.redis.utils; import...; /** *RedisUtils工具类 * *@authorchendd *@date2023/5/1922:00 */ publicfinal...

文章分类:经验分享 技术知识

Redis

Redis实践(4.2)SpringBoot 测试主从连接池

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中配置的Redis连接池是否生效的实现,虽然配置了有连接池参数,仅仅只是参数配置而已,事实上它确实是生效了吗?所以本文将使用代码来验证验证使用RedisTemplate的连接池工作机制,详见下文。 1.application.yml lettuce: pool: enabled:true max-active:8#最大连接数据库连接数,设-1为没有限制 max-idle:8#最大等待连接中的数量,设0为没有限制 max-wait:10s#最大建立连接等待时间。如果超过此时间将接到异常。设为-1表示无限制。 min-idle:0#最小等待连接中的数量,设0为没有限制 time-between-eviction-runs:10s#空闲连接回收时间 【说明】 (1)此...

文章分类:经验分享 技术知识

Redis

Redis实践(4.1)SpringBoot 测试主从RedisTemplate

前文中使用SpringBoot Data Redis项目集成了Redis的主从架构接入,本篇主要来测试一下整合后从项目中获取的RedisTemplate上下文信息以及操作redis相关的API,所以本文使用两种方式来获取RedisTemplate实例,分别是使用Spring注解和Spring Bean组件获取的工具类的形式,通过不同的RedisTemplate实例拿到不同的ConnectionFactory来验证各个实例操作的都是对应的Redis环境,详见下文。 1.注解代码 通过注解的形式注入6个容器对象,分别是2个写Redis和4个读Redis,同时包含了RedisTemplate和StringRedisTemplate,参考如下代码: package cn.chendd.redis; import ... /** * 使用@Resource注入的方式来测试redis的6个实现类,关...

文章分类:经验分享 技术知识

Redis

Redis实践(4)SpringBoot Data Redis 主从架构集成

1.基本介绍 前篇文章搭建了一个Redis的主从高可用架构,无论怎么玩也都是基于Redis客户端进行的,实际需要使用相关的Spring技术整合才是灵魂需要,所以基于这个一主二从的Redis环境来使用SpringBoot Data Redis来整合实践,本篇文章将搭建项目环境,配置相关参数。从Spring官网查看了SpringBoot Data Redis子项目的介绍信息,选择了2.7.12的稳定版本,比2.X再新的2.7.13-SNAPSHOT为快照版本,限制Spring Framework 5.3.27 且 JDK8,3.X的稳定版本限制的条件Spring Framework 6.0.9 且 JDK17,参考如下图所示 (2.7.12限制条件) (3.0.6限制条件) 2.Maven坐标 <properties> <project.build.sourceEncoding>UTF-8<...

文章分类:经验分享 技术知识

Redis
封面图片

Redis实践(3)主从复制高可用架构

1.基本介绍 Redis单击环境版仅适合学习和测试应用,因为一台服务器将承载应用的全部请求,压力较大且容量有限,所以生产环境应当考虑更高级别的可用策略,主从复制是Redis高可用中最简单的实现方式。实现Redis高可用的模式主要有三种: 主从模式、哨兵模式、集群模式。本文将基于当前最新版本Redis7.0.11来搭建的主从模式,并验证相关配置的正确性。 主从模式顾名思义是一台为主机Master,一台为从机Slave,甚至可以是多台为从机,这种结构将多台服务器的Redis服务连接为一个整体。Redis master slave 使用异步方式将数据从 master 传输到 slave。从节点会确认接收到主节点发送的数据,主节点将包含多个从节点。Redis 支持级联复制类型,因此我们的从服务器连接到另一个从服务器,为主从节点启用持久性选项是非常好的做法。基本上,主从是一种用于将数据库从一台服务器...

文章分类:经验分享 技术知识

Redis

Redis实践(2)客户端介绍

前面一篇实践了Redis的安装,也算是有了一个基础的Redis环境,本篇文章介绍一下相关的Redis的客户端,笔者并未对各个的客户端亲自实践,但总归是收集了一些官方介绍的资料进行了解和汇总,本文所述的客户端是指以客户端软件的形式访问Redis服务器,并非是具体的某个编程语言的接入框架,且看下文细细道来,以下各个客户端的排名不分先后。 1.客户端介绍 1.1 RedisInsight Redis-cli是Redis官方命令行工具,可用于执行Redis命令,并在终端中提供直观的Redis终端命令的操作体验。 Redis官方提供的客户端RedisInsight 是将图形用户界面与 Redis CLI 相结合,让您可以使用任何 Redis 部署。您可以直观地浏览数据并与之交互、利用诊断工具、通过示例学习等等。最重要的是,RedisInsight 是免费的。 RedisInsight 是一个强大的工...

文章分类:经验分享 技术知识

Redis
本站信息

 运营时间: 天

 用户数量: 人

 文章数量: 篇

 评论数量: 条

 点赞个数: 个

 最后更新:

标签云