Redis的主从复制(redis有密码版)——一主二仆、薪火相传、反客为主、哨兵模式

本文主要是介绍Redis的主从复制(redis有密码版)——一主二仆、薪火相传、反客为主、哨兵模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 搭建一主多从
    • 创建myredis文件夹并复制etc下的redis.conf到myredis下
    • 创建三个配置文件
    • 启动三个redis
    • info replication查看从属关系
    • 配置从机
    • 测试主机从机
  • 一主二仆
  • 薪火相传
  • 反客为主
  • 哨兵模式
    • 哨兵模式总结
  • 主从复制java中使用

搭建一主多从

创建myredis文件夹并复制etc下的redis.conf到myredis下

创建
mkdir /myredis
进入文件夹
cd /myredis
复制操作
cp /etc/redis.conf /myredis/redis.conf

可以看到刚开始ls没有的,复制完ls就可以看见redis.conf文件了
在这里插入图片描述

创建三个配置文件

创建第一个
vim redis6379.conf

配置里面
include /myredis/redis.conf
pidfile /var/run/redis_6379.pid
port 6379
dbfilename dump6379.rdb

然后再创建两个分别取名 redis6380.conf redis6381.conf
可以像这样复制 会快一点

cp redis6379.conf redis6380.conf
复制过来的记得修改里面的配置把6379全改成6380

ls
在这里插入图片描述
这时候就创建完成了

启动三个redis

在这里插入图片描述
成功了是这样的
在这里插入图片描述
如果6379和我显示的不一样 说明端口号被占用 先杀掉再开就行

info replication查看从属关系

在这里插入图片描述
可以看到 角色是主机,从机0

配置从机

在从机上执行slaveof 主机ip 主机端口号

在6380和6381上执行: slaveof 127.0.0.1 6379

**这里提一嘴如果redis配置了密码需要在从库的conf里添加
masterauth 密码 不然配置从库的时候从库显示有主库 主库却看不见从库
**

先配了一个 反正成功是这样的
在这里插入图片描述

测试主机从机

主机创建了 a1 v1
在这里插入图片描述
从机可以直接获取,且从机无法添加,只有读的功能
在这里插入图片描述

一主二仆

特点:

1.从机挂了之后需要重新(执行slaveof 主机ip 主机端口号) 不然从机就会变回主机
.
2.挂掉之后重新配置回从机时 会把主机数据从头到尾复制
.
3.主机挂了之后从机还是从机(不会变成主机) 并且显示主机状态为down 等主机恢复之后 主机就还是主机 从机也还是从机

薪火相传

比如6380是6379的从机 slaveof 127.0.0.1 6379
6381是6380的从机 slaveof 127.0.0.1 6380

特点:上一个Slave可以是下一个slave的Master,Slave同样可以接收其他 slaves的连接和同步请求,那么该slave作为了链条中下一个的master, 可以有效减轻master的写压力,去中心化降低风险

优点:减少压力
缺点:其中一个挂了,后面的都没了

反客为主

在从机设计slaveof no one 这是当主机挂了之后 这个从机会变成主机
但是变成的只是普通主机 如果是薪火相传的话他的从机还是他的从机
其他和他并列的从机不会变成他的从机

哨兵模式

首先前提是一主二从,二从是并列的而不是薪火相传
下面开始测试

  1. 在myredis下再建一个配置文件 sentinel.conf
  2. 打开配置类,在里面添加 sentinel monitor mymaster 127.0.0.1 6379 1
    其中mymaster为监控对象起的服务器名称,1 为至少有多少个哨兵同意迁移(只要有一个哨兵同意即可迁移)。
  3. 再添加sentinel auth-pass mymaster 密码
  4. redis-sentinel sentinel.conf 启动哨兵模式
  5. 关掉6379端口的主机
    在这里插入图片描述
  6. 这时哨兵模式启动了开始加载配置
    在这里插入图片描述

可以看到6379端口down了,新主机为6381,这是6380为6381从机
在这里插入图片描述
在这里插入图片描述
这时候如果重新启动6379端口,可以看到他已经变成从机了,主机为6381
在这里插入图片描述

哨兵模式总结

当主服务器down机时,新服务器选举是有策略的
选择条件从上到下依次
1.选择优先级靠前的
优先级在redis.conf中默认:replica-priority 100,值越小优先级越高
2.选择偏移量最大的
偏移量是指获得原主机数据最全的
3.选择runid最小的从服务
每个redis实例启动后都会随机生成一个40位的runid

主从复制java中使用

引用即可

private static JedisSentinelPool jedisSentinelPool=null;public static  Jedis getJedisFromSentinel(){
if(jedisSentinelPool==null){Set<String> sentinelSet=new HashSet<>();sentinelSet.add("192.168.11.103:26379");JedisPoolConfig jedisPoolConfig =new JedisPoolConfig();jedisPoolConfig.setMaxTotal(10); //最大可用连接数
jedisPoolConfig.setMaxIdle(5); //最大闲置连接数
jedisPoolConfig.setMinIdle(5); //最小闲置连接数
jedisPoolConfig.setBlockWhenExhausted(true); //连接耗尽是否等待
jedisPoolConfig.setMaxWaitMillis(2000); //等待时间
jedisPoolConfig.setTestOnBorrow(true); //取连接的时候进行一下测试 ping pongjedisSentinelPool=new JedisSentinelPool("mymaster",sentinelSet,jedisPoolConfig);
return jedisSentinelPool.getResource();}else{
return jedisSentinelPool.getResource();}
}

这篇关于Redis的主从复制(redis有密码版)——一主二仆、薪火相传、反客为主、哨兵模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/832814

相关文章

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

redis-cli命令行工具的使用小结

《redis-cli命令行工具的使用小结》redis-cli是Redis的命令行客户端,支持多种参数用于连接、操作和管理Redis数据库,本文给大家介绍redis-cli命令行工具的使用小结,感兴趣的... 目录基本连接参数基本连接方式连接远程服务器带密码连接操作与格式参数-r参数重复执行命令-i参数指定命

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

Redis过期键删除策略解读

《Redis过期键删除策略解读》Redis通过惰性删除策略和定期删除策略来管理过期键,惰性删除策略在键被访问时检查是否过期并删除,节省CPU开销但可能导致过期键滞留,定期删除策略定期扫描并删除过期键,... 目录1.Redis使用两种不同的策略来删除过期键,分别是惰性删除策略和定期删除策略1.1惰性删除策略

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re