主从复制概念

主从复制指将一台redis的数据复制另外一台redis服务器上,前者称为主节点(master),后者称为从节点(slave)。

注意复制的过程是单向的,只能从主节点到从节点,主节点以写为主,从节点以读为主。

主从复制的作用

数据冗余:主从复制实现了数据的热备份

故障恢复:当主节点出现问题时,可以由从节点提供服务,快速恢复故障

负载均衡:主节点复制写数据,从节点负责读数据,实现读写分离分担服务器负载。

最常见的主从复制架构如下图所示

手动实现主从复制

开启三个redis服务,例如开启三个端口分别为6379、6380、6381三台redis服务,未设置谁是主节点之前,默认每台服务都是主节点的,

info replication #查看节点信息

这里为了演示所以配置了伪集群,即一台机器启动三个redis服务,只是不同端口。注意启动6380和6381需要增加一个redis配置文件,例如启动6380时复制一份redis.conf修改名字为redis6380.conf,然后修改配置文件中的以下几个地方。

daemonize yes #后台启动修改为yes

pidfile /var/run/redis_6380.pid #修改进程文件的名称

logfile "6380.log" #日志文件的名称

dbfilename dump6380.rdb #rdb文件的名称

port 6380 #端口号

使用命令查看启动好的redis

ps -ef|grep redis

正式配置一主二从

因为redis启动默认是主节点,所以主需要将6380和6379的设置为6379的从节点就行了,设置redis6380的主节点为6379,使用slaveof [主节点IP] [主节点端口]

slaveof 127.0.0.1 6379

使用同样的方式设置6381,最后回到主节点6379进行查看节点信息

至此我们就把一主二从的架构的配置好了,下面测试一下,主机写入数据后,会不会将数据自动同步到从机中。

主机设置一个key为test1

从机进行获取test1

进过测试,没问题,大功告成!

你以为这就完了么,有的同学会问,当主机挂了会怎么样,这个问题问的好。这种手动模式的一主二从架构,当主机挂了之后需要人为的手动重新设置一个主机,才能正常工作。说到这里,是不是会觉得这也太low了吧,讲这个有啥用,其实讲这个是为了让你清楚主从复制真正的工作原理。那么为了解决这个当主机挂了,需要手动重新设置一个主节点的问题,就需要使用我们的哨兵模式。

什么是哨兵

顾名思义,哨兵就是用来巡逻检查的,哨兵每隔一段时间会向redis发送命令,等待redis响应,如果得不到响应,此时这个哨兵会认为这台redis服务以挂掉。一般情况会启动多个哨兵,判断redis主机是否挂掉,哨兵会进行投票。例如启动三个哨兵,其中有两个哨兵认为当前redis主机以挂掉,一个认为没有,那么2:1,那可以认为当前redis挂掉了。当主节点挂掉后,哨兵会通过投票的方式重新选举一个主机。

哨兵的作用

通过发送命令,让redis服务器返回运行状态,包括主服务器和从服务器。

当哨兵检测到master宕机后,会通过投票选举新的master,然后通过发布订阅模式通知其它从机切换主机。

配置哨兵

在/opt/redis-6.0.7/myconf目录下添加哨兵配置文件 sentinel.conf内容如下

sentinel monitor myredis 127.0.0.1 6379 1

意思监控master,后面的1表示当master挂了后是否发起投票。

开启一个终端,进入redis目录

启动哨兵:./src/redis-sentinel myconf/sentinel.conf

下面测试如果master宕机了,会不会重新选举一个新的master。

现在手动把master关掉,等待几秒钟可以看到master主机变成了6380

如果此时原来的主机恢复正常了呢,会不会重新这是其为master,答案是否定的,原来的主机恢复正常后,只能作为新主机的从节点。

好了,写了这么多终于把redis的注册复制写完了!

------------------------------------------------END-----------------------------------------------------------------

你的一个赞一个关注是我创作的动力,是我持续输出的能量源泉,老铁关注一波吧!

实现redis 手动_Redis精华所在,一口气说完Redis的主从复制和哨兵模式相关推荐

  1. 一篇掌握Redis的主从复制机制+哨兵模式

    1. 什么是主从复制 主从复制是主机数据更新后根据配置和策略, 自动同步到备机的master/slave机制,Master以写为主,Slave以读为主 2.主从复制的作用 数据冗余:主从复制实现了数据 ...

  2. Redis数据库(三)——(主从复制、哨兵模式、集群)

    Redis数据库(三)--(主从复制.哨兵模式.集群) 一.Redis主从复制 1.Redis主从模式介绍 2.Redis主从复制的流程 3.Redis主从复制的作用 4.Redis主从复制的搭建 环 ...

  3. 6 redis 编译失败_Centos7.8环境搭建Redis主从复制和哨兵模式

    本节我们搭建Redis主从复制和哨兵模式集群,集群的好处是把数据分散不不同的服务器上,解决网站中的很多高并发,高负载等问题,很好的提高网站的性能,也能解决mysql的数据读写问题,所以我们搭建集群非常 ...

  4. Redis(主从复制、哨兵模式、集群)概述及部署

    Redis(主从复制.哨兵模式.集群)概述及部署 前言 一.主从复制 (1)主从复制原理 (2)主从复制作用 (3)主从复制流程 (4)搭建主从复制 ①修改master节点配置文件 ②修改Slave节 ...

  5. 深入学习 Redis 之第 2 篇 —— Docker 实现 Redis 主从复制之哨兵模式 Sentinel

    查看之前的博客可以点击顶部的[分类专栏] 本篇博客基于第1篇博客的环境基础上继续实验的: https://blog.csdn.net/BiandanLoveyou/article/details/11 ...

  6. mysql 哨兵模式_Redis讲解主从复制和哨兵模式

    推荐(免费):redis 文章目录主从复制 命令 配置 复制原理 全量复制 增量复制 测试 嵌套主从 哨兵模式 配置哨兵 测试 主从复制 主从复制指的是把一台Redis服务器的数据复制到其他Redis ...

  7. Redis高可用:主从复制及哨兵模式

    目录 主从复制 作用 复制原理 使用的方式 哨兵模式 主从切换过程 Redis Sentinel的配置文件 参考 主从复制 主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器.前 ...

  8. Redis主从复制、哨兵模式和分布式集群

    为什么需要集群和高可用 为什么需要主从复制 主要是安全性和可用性的考虑,如果只有一个redis服务,一旦服务宕机,那么所有的客户端无法访问,会对业务造成很大影响,另一个是一旦硬件损坏,单机无法恢复,会 ...

  9. 2.6_11 Redis主从复制、哨兵模式、分片集群

    相关链接 Excel目录 redis官网 redis中文网 Redis集群 1) 主从复制replication:一个master,多个slave,要几个slave取决于要求的读吞吐量[10万QPS/ ...

最新文章

  1. static_cast与c风格的强制类型转换比较
  2. G - Bad Hair Day (单调栈)
  3. 如何从0到1搭建电商促销系统?
  4. 热部署插件JRebel使用解决方案(安装+踩坑+使用方法)傻瓜式超详细!!!
  5. php怎么解决雪崩或穿透,Redis之缓存击穿、穿透、雪崩、预热,以及如何解决?...
  6. vue-router和react-router嵌套路由layout配置方案的区别
  7. spring自动装配依赖包_解决Spring自动装配中的循环依赖
  8. debugging Auto Layout:Logical Errors
  9. [gkk传智]static与多态及向下向上转型,及多态调用总结
  10. 在linux下使用ftp客户端命令
  11. 《图解算法》学习之算法复杂度、运行时间
  12. android textview显示表情,Android开发-TextView中显示QQ表情类的图片和超链接
  13. Laravel 结合TCPDF生成PDF
  14. 非著名不专业Teambition网盘评测
  15. 大公司还是大城市该怎么选择?
  16. 试题 基础练习 字母图形
  17. 2021杭州·云栖大会来了!门票免费预约
  18. 【presto】presto 参数配置优化
  19. 投资理财-简单策略其实不简单
  20. 【时间管理】 -- 顺应人性的时间管理法

热门文章

  1. python实现提取jira bug列表
  2. Python基础教程:新式类与经典类
  3. django中使用POST方法 获取POST数据
  4. linux没有mysql.server,[linux]centos7下解决yum install mysql-server没有可用包
  5. mysql 5.7.11 my.ini,mysql5.7以上版本配置my.ini的详细步骤
  6. python opencv cv2.namedWindow(winname, flags=None) (命名)创建窗口 cv::WindowFlags
  7. Python 将两层列表展开平铺成一层
  8. 初学__Python——Python 函数参数的使用
  9. linux——apache
  10. maven安装、配置以及IDEA创建maven项目(Maven的Web项目)