您当前的位置:首页 > 电脑百科 > 数据库 > Redis

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

时间:2020-11-16 11:16:58  来源:  作者:

主从复制概念

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

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

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

主从复制的作用

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

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

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

 

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

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

手动实现主从复制

 

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

info replication #查看节点信息

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

这里为了演示所以配置了伪集群,即一台机器启动三个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精华所在,一口气说完Redis的主从复制和哨兵模式

 

使用命令查看启动好的redis

ps -ef|grep redis

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

正式配置一主二从

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

slaveof 127.0.0.1 6379

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

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

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

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

主机设置一个key为test1

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

从机进行获取test1

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

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

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

什么是哨兵

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

Redis精华所在,一口气说完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

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

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

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

Redis精华所在,一口气说完Redis的主从复制和哨兵模式

 

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

 

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



Tags:Redis   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
来源: my.oschina.net/xiaomu0082/blog/2990388首先说下问题现象:内网sandbox环境API持续1周出现应用卡死,所有api无响应现象刚开始当测试抱怨环境响应慢的时候 ,我们重启一下应...【详细内容】
2021-12-08  Tags: Redis  点击:(16)  评论:(0)  加入收藏
我不知道为什么你会选择对特定数量的“错误”(或警告)如此具体。听起来您正在寻找将要发布到 Yahoo! 的某些文章的内容。 Insider (N Foos to Blah for the BlahBlah)。那说:...【详细内容】
2021-12-07  Tags: Redis  点击:(14)  评论:(0)  加入收藏
目录 一、背景 二、步骤 0.理论支持 1、获取数据 2、结果 3、分析数据并评估大小 三、关于repl-backlog-size 一、背景 repl-backlog-size控制这个环形缓冲区. ​ 主从断...【详细内容】
2021-11-05  Tags: Redis  点击:(41)  评论:(0)  加入收藏
Redis 性能测试是通过同时执行多个命令实现的。1,Redis-benchmarkRedis性能命令:redis性能命令格式: redis-benchmark [option] [option value] redis 性能测试工具可选参数如...【详细内容】
2021-11-02  Tags: Redis  点击:(41)  评论:(0)  加入收藏
1 概述数据结构和内部编码 无传统关系型数据库的 Table 模型schema 所对应的db仅以编号区分。同一 db 内,key 作为顶层模型,它的值是扁平化的。即 db 就是key的命名空间。 key...【详细内容】
2021-11-01  Tags: Redis  点击:(28)  评论:(0)  加入收藏
普通java中使用引用Java redis 驱动,即可连接:import redis.clients.jedis.Jedis; public class RedisTestJava { public static void main(String[] args) { //连...【详细内容】
2021-10-13  Tags: Redis  点击:(34)  评论:(0)  加入收藏
Redis常用的数据结构有 string list set zset hashstringstring 是 Redis 的基本的数据类型,一个 key 对应一个 value。string 类型是二进制安全的,Redis的string可以包含任...【详细内容】
2021-10-12  Tags: Redis  点击:(36)  评论:(0)  加入收藏
列表类型可以存储一组按插入顺序排序的字符串,它非常灵活,支持在两端插入、弹出数据,可以充当栈和队列的角色。> LPUSH fruit apple(integer) 1> RPUSH fruit banana(integer)...【详细内容】
2021-09-17  Tags: Redis  点击:(54)  评论:(0)  加入收藏
Redis持久化意义 是做灾难恢复,数据恢复,也可以归类到高可用的一个环节里面去,比如你的redis整个挂了,然后redis就不可用了,你要做的事情是让redis变得可用,尽快变得可用 大量的请...【详细内容】
2021-08-12  Tags: Redis  点击:(77)  评论:(0)  加入收藏
Nginx来限制访问控制的方法有多种,nginx主要有2个模块控制,但是那些不支持自定义,非常死,在大多数场景下并不实用。今天分享一个:利用openresty+lua+redis 实现封杀频繁恶意访问I...【详细内容】
2021-08-12  Tags: Redis  点击:(118)  评论:(0)  加入收藏
▌简易百科推荐
来源: my.oschina.net/xiaomu0082/blog/2990388首先说下问题现象:内网sandbox环境API持续1周出现应用卡死,所有api无响应现象刚开始当测试抱怨环境响应慢的时候 ,我们重启一下应...【详细内容】
2021-12-08  Java识堂    Tags:Redis   点击:(16)  评论:(0)  加入收藏
我不知道为什么你会选择对特定数量的“错误”(或警告)如此具体。听起来您正在寻找将要发布到 Yahoo! 的某些文章的内容。 Insider (N Foos to Blah for the BlahBlah)。那说:...【详细内容】
2021-12-07  富集云科技有限公司    Tags:Redis   点击:(14)  评论:(0)  加入收藏
目录 一、背景 二、步骤 0.理论支持 1、获取数据 2、结果 3、分析数据并评估大小 三、关于repl-backlog-size 一、背景 repl-backlog-size控制这个环形缓冲区. ​ 主从断...【详细内容】
2021-11-05  弈秋的美好生活    Tags:redis   点击:(41)  评论:(0)  加入收藏
Redis 性能测试是通过同时执行多个命令实现的。1,Redis-benchmarkRedis性能命令:redis性能命令格式: redis-benchmark [option] [option value] redis 性能测试工具可选参数如...【详细内容】
2021-11-02  川石信息    Tags:Redis   点击:(41)  评论:(0)  加入收藏
1 概述数据结构和内部编码 无传统关系型数据库的 Table 模型schema 所对应的db仅以编号区分。同一 db 内,key 作为顶层模型,它的值是扁平化的。即 db 就是key的命名空间。 key...【详细内容】
2021-11-01  JavaEdge    Tags:Redis   点击:(28)  评论:(0)  加入收藏
普通java中使用引用Java redis 驱动,即可连接:import redis.clients.jedis.Jedis; public class RedisTestJava { public static void main(String[] args) { //连...【详细内容】
2021-10-13  faesuite    Tags:Redis   点击:(34)  评论:(0)  加入收藏
Redis常用的数据结构有 string list set zset hashstringstring 是 Redis 的基本的数据类型,一个 key 对应一个 value。string 类型是二进制安全的,Redis的string可以包含任...【详细内容】
2021-10-12  语霖    Tags:Redis   点击:(36)  评论:(0)  加入收藏
列表类型可以存储一组按插入顺序排序的字符串,它非常灵活,支持在两端插入、弹出数据,可以充当栈和队列的角色。> LPUSH fruit apple(integer) 1> RPUSH fruit banana(integer)...【详细内容】
2021-09-17  深夜敲代码    Tags:Redis   点击:(54)  评论:(0)  加入收藏
Redis持久化意义 是做灾难恢复,数据恢复,也可以归类到高可用的一个环节里面去,比如你的redis整个挂了,然后redis就不可用了,你要做的事情是让redis变得可用,尽快变得可用 大量的请...【详细内容】
2021-08-12  小李说IT    Tags:Redis   点击:(77)  评论:(0)  加入收藏
当查询Redis中没有的数据时,该查询会下沉到数据库层,同时数据库层也没有该数据,当这种情况大量出现或被恶意攻击时,接口的访问全部透过Redis访问数据库,而数据库中也没有这些数据...【详细内容】
2021-07-30  随便t    Tags:缓存穿透   点击:(90)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条