-关于redis主从同步延迟的信息(6-9-35)
更新时间:2024-11-12 分类:Redis 浏览量:2
Redis本文目录一览:
- 1、redis主从和哨兵
- 2、redis主从架构高可用如何实现
- 3、大厂面试题详解:如何用Redis实现分布式锁?
- 4、Redis主从复制丢失数据的情况分析
redis主从和哨兵
配置3个哨兵和1主2从的Redis服务器来演示这个过程。首先配置Redis的主从服务器,修改redis.conf文件如下 主从服务器都需要配置 配置3个哨兵,每个哨兵的配置都是一样的。
主从模式指的是使用一个Redis实例作为主机,其余的实例作为备份机。一般来说主节点负责写请求,从节点负责读请求,主节点异步的同步给从节点。主节点和从节点保存的数据是相同的,但是因为同步,从节点的数据会有一点延迟。
Redis 高可用的主要有三种模式: 主从模式, 哨兵模式和集群模式。 Redis 提供了 Redis 提供了复制(replication)功能,当一台 redis 数据库中的数据发生了变化,这个变化会被自动地同步到其他的 redis 机器上去。
哨兵提供的消息订阅频道有很多,不同频道包含了主从库切换过程中的不同关键事件。具体的操作步骤是,客户端读取哨兵的配置文件后,可以获得哨兵的地址和端口,和哨兵建立网络连接。
首先配置Redis的主从服务器,修改redis.conf文件如下 上述内容主要是配置Redis服务器,从服务器比主服务器多一个slaveof的配置和密码。配置3个哨兵,每个哨兵的配置都是一样的。
一般需要三个节点,每个节点有一个 redis 和一个哨兵。下面再分别描述。我这里按三个 节点,先配置 redis 的主从复制。1个节点作为 master ,2个副本。
redis主从架构高可用如何实现
1、redis高可用:如果你做主从架构部署,其实就是加上哨兵就可以了,就可以实现,任何一个实例宕机,自动会进行主备切换。
2、以下是一个简单的步骤: 创建一个 ConfigMap,其中包含 Redis 配置文件。 创建一个 StatefulSet,其中包含 3 个副本的 Redis Pod。 创建一个 PersistentVolumeClaim,用于存储 Redis 数据。
3、新版本Redis使用psync命令来代替sync命令,该命令既可以实现完整全同步也可以实现部分同步。
4、Sentinel : redis 自带的主从切换工具,我们通过 sentinel 实现集群高可用。客户端( Smart Client ):客户端通过约定查找 redis 实例在 ZooKeeper 中写入的地址。
大厂面试题详解:如何用Redis实现分布式锁?
直接使用 set(key,value,NX,EX,timeout) 指令,同时设置锁和超时时间。 以上两种方法,使用哪种方式都可以。 释放锁的脚本两种方式都一样,直接调用 Redis 的 del 指令即可。
可以尽量把锁自动过期的时间设的冗余一些。但也不能彻底解决。可以在删除锁的时候先get值,判断值是否是当前线程存的随机值,只有相同才执行删锁的操作;当然也要使用 lua 脚本执行来保证原子性。
如返回1,则该客户端获得锁,把lock.foo的键值设置为时间值表示该键已被锁定,该客户端最后可以通过DEL lock.foo来释放该锁。如返回0,表明该锁已被其他客户端取得,这时我们可以先返回或进行重试等对方完成或等待锁超时。
Redis主从复制丢失数据的情况分析
这样一来,主从切换完成后,也只有新主库能接收请求,不会发生脑裂,也就不会发生数据丢失的问题了。主从数据不一致,就是指客户端从从库中读取到的值和主库中的最新值并不一致。
Redis中的Map被误删除:在某些情况下,可能会出现误删除Map的情况,例如在操作时误执行了DEL命令或者使用了错误的键名。
可能有人会遇到,Redis 经常会丢掉一些数据,写进去了,过一会儿可能就没了。那么你可能是将Redis当成存储了而没有当作缓存。啥叫缓存?用内存当缓存。内存是无限的吗,内存是很宝贵而且是有限的,磁盘是廉价而且是大量的。