Redis————主从架构

这篇具有很好参考价值的文章主要介绍了Redis————主从架构。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

主从架构搭建

单机多实例

  1. 粗制一份redis.conf文件

  2. 将相关配置修改为如下值:

    port 与主节点端口后不相同即可
    pidfile pid进程号保存文件pidfile的路径
    logfile 日志文件名称
    dir 指定数据存放目录
    #需要注释掉bind
    #bind 127.0.0.1(bind绑定的是自己机器网卡的ip,如果有多块网卡可以配置多个ip,代表客户端通过机器的哪些网卡ip去访问,内网一般可以不配置bind,注释掉即可)

  3. 配置主从复制

    replicaof ip port # 从主机port端口的redis实力复制数据,Redis5.0之前时候slaveof
    replica-read-only yes # 配置从节点为只读
    
  4. 启动从节点
    redis-server 从节点配置文件

  5. 连接从节点
    redis-cli -p 从节点端口号

  6. 测试在主节点写数据,从节点是否能及时同步新修改的数据

多机多实例

只需要将修改该服务器上redis配置文件

replicaof ip port # 从主机port端口的redis实力复制数据,Redis5.0之前时候slaveof
replica-read-only yes # 配置从节点为只读

Redis主从工作原理

数据全量复制

如果你为master配置了一个slave,不管这个slave是否是第一次连接上Master,它都会发送一个PSYNC
命令给master请求复制数据。
master收到PSYNC命令后,会在后台进行数据持久化通过bgsave生成最新的rdb快照文件,持久化期
间,master会继续接收客户端的请求,它会把这些可能修改数据集的请求缓存在内存中。当持久化进行完
毕以后,master会把这份rdb文件数据集发送给slave,slave会把接收到的数据进行持久化生成rdb,然后
再加载到内存中。然后,master再将之前缓存在内存中的命令发送给slave。
当master与slave之间的连接由于某些原因而断开时,slave能够自动重连Master,如果master收到了多
个slave并发连接请求,它只会进行一次持久化,而不是一个连接一次,然后再把这一份持久化的数据发送
给多个并发连接的slave。

主从复制(全量复制)流程图

Redis————主从架构,redis,架构,bootstrap

数据部分复制

当master和slave断开重连后,一般都会对整份数据进行复制。但从redis2.8版本开始,redis改用可以支
持部分数据复制的命令PSYNC去master同步数据,slave与master能够在网络连接断开重连后只进行部分
数据复制(断点续传)。
master会在其内存中创建一个复制数据用的缓存队列,缓存最近一段时间的数据,master和它所有的
slave都维护了复制的数据下标offset和master的进程id,因此,当网络连接断开后,slave会请求master
继续进行未完成的复制,从所记录的数据下标开始。如果master进程id变化了,或者从节点数据下标
offset太旧,已经不在master的缓存队列里了,那么将会进行一次全量数据的复制。

主从复制(部分复制,断点续传)流程图

Redis————主从架构,redis,架构,bootstrap

Redis哨兵高可用架构

架构图

Redis————主从架构,redis,架构,bootstrap

redis哨兵架构搭建步骤

单机多实例

  1. 复制一份sentinel.conf文件
  2. 将相关配置修改为如下值:
    port 与原sentinel区分开即可
    daemonize yes
    pidfile 进程号保存文件
    logfile 日志文件
    dir 数据保存目录
    #sentinel monitor <master‐redis‐name> <master‐redis‐ip> <master‐redis‐port>
    #quorum是一个数字,指明当有多少个sentinel认为一个master失效时(值一般为:sentinel总数/2 +
    1),master才算真正失效
    sentinel monitor mymaster 192.168.0.60 6379 2 # mymaster客户端访问时会用
  3. 启动sentinel哨兵实例
    redis-sentinel 对应的配置文件

多机多实例

上述配置中只需要修改
sentinel monitor <master‐redis‐name> <master‐redis‐ip> <master‐redis‐port>
即可

哨兵的Spring Boot整合Redis连接代码见示例

  1. 引入相关依赖

    <dependency>
    	<groupId>org.springframework.boot</groupId>
    	<artifactId>spring‐boot‐starter‐data‐redis</artifactId>
    </dependency>
    <dependency>
    	<groupId>org.apache.commons</groupId>
    	<artifactId>commons‐pool2</artifactId>
    </dependency>
    
  2. springboot项目核心配置

    server:
    	port: 8080
    spring:
    	redis:
    		database: 0
    		timeout: 3000
    		sentinel:
    			master: master
    			nodes: 192.168.0.60:26379,192.168.0.60:26380,192.168.0.60:26381
    		lettuce:
    			pool:
    				max-idle: 50
    				min-idle: 10
    				max-active: 100
    				max-wait: 1000
    
  3. 访问代码文章来源地址https://www.toymoban.com/news/detail-522589.html

    @RestController
    public class RedisTestController {
    	@Autowired
    	private StringRedisTemplate stringRedisTemplate;
    
    	@RequestMapping("/test")
    	public void testSentinel() throws InterruptedException {
    		int i = 1;
    		while (true){
    			try {
    				stringRedisTemplate.opsForValue().set("lzh"+i, i+"");
    				System.out.println("设置key:"+ "lzh" + i);
    				i++;
    				Thread.sleep(1000);
    			}catch (Exception e){
    				logger.error("错误:", e);
    			}
    		}
    	}
    }
    
    

到了这里,关于Redis————主从架构的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Redis系列3:高可用之主从架构

    上一篇《Redis系列2:数据持久化提高可用性》中,我们介绍了Redis中的数据持久化技术,包括 RDB快照 和 AOF日志 。有了这两个利器,我们再也不用担心机器宕机,数据丢失了。 但是持久化技术只是解决了Redis服务故障之后,快速数据恢复的问题。并没有从根本上提升Redis的可

    2024年04月27日
    浏览(39)
  • Redis 架构深入:主从复制、哨兵到集群

    大家好,我是小康,今天我们来聊下 Redis 的几种架构模式,包括 主从复制、哨兵和集群模式 。 设想一下,你的咖啡馆在城市中太受欢迎,导致每天都人满为患。为了缓解这种压力,你决定在其他地方开设分店,这样顾客就可以在附近的分店享受咖啡,而不必涌向一个地方,

    2024年03月10日
    浏览(64)
  • 《面试1v1》Redis主从架构

    🍅 作者简介:王哥,CSDN2022博客总榜Top100🏆、博客专家💪 🍅 技术交流:定期更新Java硬核干货,不定期送书活动 🍅 王哥多年工作总结:Java学习路线总结, 点击 突击面试 🍅 数十万人的面试选择: 面试说人话系列《面试1v1》 我是 javapub,一名 Markdown 程序员从👨‍💻,

    2024年02月11日
    浏览(36)
  • redis持久化、主从和哨兵架构

    1、RDB快照(snapshot) redis配置RDB存储模式,修改redis.conf文件如下配置:  也可以在连接redis时手动输入save或者bgsave命令都会将所有redis内存快照生成到一个新的dump.rdb文件,并覆盖原来的rdb文件 bgsave写时复制(COW)机制 主线程在执行redis命令,在内存中生成副本的同时由主线

    2024年02月09日
    浏览(27)
  • Redis持久化、主从与哨兵架构详解

    在默认情况下, Redis 将内存数据库快照保存在名字为 dump.rdb 的二进制文件中。 你可以对 Redis 进行设置, 让它在“ N 秒内数据集至少有 M 个改动”这一条件被满足时, 自动保存一次数据集。 比如说, 以下设置会让 Redis 在满足“ 60 秒内有至少有 1000 个键被改动”这一条件时

    2024年02月09日
    浏览(28)
  • 【Redis】Redis三种集群模式-主从、哨兵、集群各自架构的优点和缺点对比

    如果Redis的读写请求量很大,那么单个实例很有可能承担不了这么大的请求量,如何提高Redis的性能呢?你也许已经想到了,可以部署多个副本节点,业务采用读写分离的方式,把读请求分担到多个副本节点上,提高访问性能。要实现读写分离,就必须部署多个副本,每个副本

    2024年02月12日
    浏览(30)
  • Redis主从架构、数据同步原理、全量同步、增量同步

    大家好,我是哪吒。 2023年再不会Redis,就要被淘汰了 图解Redis,谈谈Redis的持久化,RDB快照与AOF日志 Redis单线程还是多线程?IO多路复用原理 Redis集群的最大槽数为什么是16384个? Redis缓存穿透、击穿、雪崩到底是个啥?7张图告诉你 Redis分布式锁的实现方式 Redis分布式缓存、

    2024年02月07日
    浏览(56)
  • Redis主从复制和哨兵架构图,集成Spring Boot项目实战分享

    Redis 主从复制和哨兵架构是 Redis 集群的重要组成部分,用于提高 Redis 集群的可用性和性能。以下是 Redis 主从复制和哨兵架构的详细介绍,包括架构图和 Java 代码详解。 Redis 主从复制是通过节点间的异步复制实现的。在 Redis 集群中,每个主节点可以有多个从节点,每个从节

    2024年02月13日
    浏览(26)
  • Redis最新版本搭建主从环境,Redis主从复制环境搭建

    一般网站搭建都会使用Redis做缓存,当单台Redis承受不住压力时,会考虑搭建Redis主从。在没有业务的情况下,一般不会一下子上来就去搭建Redis无中心集群 Redis主从复制环境搭建 ,前面跟部署单台Redis一致,只不过后面 是从Redis的配置上去同步主Redis即可 。 这里找三台虚拟机

    2024年01月21日
    浏览(27)
  • 【Redis】Redis主从复制

    主从复制, master 以写为主, slave 以读为主。 当 master 数据变化的时候,自动将新的数据异步同步到其他 slave 数据库。 读写分类 容灾备份 数据备份 水平扩容支持高并发 环境要求 :一个 Master ,两个 Slave ——3台虚拟机,每台都安装 redis 主机 master 配置 将redis压缩包中原装

    2024年02月01日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包