redis三主三从原理图-redis三主三从作用(6-5-88)
更新时间:2024-07-26 分类:Redis 浏览量:2
Redis本文目录一览:
- 1、redis有哪些集群模式
- 2、redis是用来干什么的
- 3、Redis的主要功能?
- 4、玩转Redis的高可用(主从、哨兵、集群)
- 5、如何避免Redis集群脑裂?
- 6、如何查看redis的sentinel
redis有哪些集群模式
/www/server/redis/src/redis-server /www/server/redis/redis.conf 查看redis是否在运行 ps aux|grep redis 现在是单机redis模式完成。
传统的Redis集群采用的主从复制模式,一般为一主多从,主节点有读写权限,但是从节点只有读的权限。主节点会定期将数据同步到从节点中,保证数据一致性的问题。
哨兵模式就是在主从模式的基础上再加一个哨兵集群。每个哨兵都会监控主节点和从节点的状态。如果主节点挂了,就会从从节点中选出一个来作为主节点,以达到高可用的目的。
redis是用来干什么的
1、Redis是由意大利人Salvatore Sanfilippo(网名:antirez)开发的一款内存高速缓存数据库。
2、消息队列、分布式锁。消息队列:Redis可以作为一种高性能的消息队列使用,实现异步处理和解耦。分布式锁:Redis可以作为一种分布式锁的存储层,通过缓存锁信息和锁状态,实现分布式锁和并发控制。
3、Redis是一种开源的内存数据存储系统,用于缓存存储频繁访问的数据,减轻数据库的负载。Redis还可用于发布订阅系统,支持多个客户端通过订阅频道来接收实时的消息,从而实现聊天应用、新闻推送等。
Redis的主要功能?
redis是一个单线程的NoSQL数据库,主要用来做数据缓存,一般大型网站的应用和数据库之间的那一层就是Redis。
Redis简介Redis是一个高性能的key-value数据库。Redis 与其他 key - value 缓存产品有以下三个特点:- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
redis叫做远程字典服务,是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)和zset(有序集合)。
Redis支持发布订阅模式,可以用于实现实时消息推送、事件通知等场景。发布者将消息发布到特定的频道,订阅者可以订阅感兴趣的频道并接收消息,实现消息的实时分发。
所以这个时候Redis的持久化功能就派上用场了,可以缓解一下缓存雪崩带来的影响。redis的持久化指的是redis会把内存的中的数据写入到硬盘中,在redis重新启动的时候加载这些数据,从而最大限度的降低缓存丢失带来的影响。
可以利用Redis的setnx功能来编写分布式的锁,如果设置返回1说明获取锁成功,否则获取锁失败,实际应用中要考虑的细节要更多。
玩转Redis的高可用(主从、哨兵、集群)
1、基于以上,Redis集群方案显得尤为重要。通常有3个途径:官方Redis Cluster;通过Proxy分片;客户端分片(Smart Client)。以上三种方案各有利弊。
2、主从复制可以提高Redis集群的可用性,当主节点出现故障时,从节点可以自动或者手动替代主节点的职责,从而保证Redis集群的高可用性。
3、哨兵集群,基于主从复制模式,所有的主从配置优点,它全有。主从可以切换,故障可以转移,系统的可用性就会更好。哨兵模式就是主从模式的升级,手动到自动,更加健壮。集群容量一旦到达上限,在线扩容十分麻烦。
4、主节点会定期将数据同步到从节点中,保证数据一致性的问题。这种集群方式在运行时存在一些问题:Redis的哨兵机制就是解决主从复制存在缺陷(选举问题),解决问题保证我们的Redis高可用,实现自动化故障发现与故障转移。
5、哨兵模式就是在主从模式的基础上再加一个哨兵集群。每个哨兵都会监控主节点和从节点的状态。如果主节点挂了,就会从从节点中选出一个来作为主节点,以达到高可用的目的。
6、原理:当主节点出现故障时,由Redis Sentinel自动完成故障发现和转移,并通知应用方,实现高可用性。
如何避免Redis集群脑裂?
1、设置为0关闭该功能。redis集群没有过半机制会有脑裂问题,网络分区导致脑裂后多个主节点对外提供写服务,一旦网络分区恢复,会将其中一个主节点变为从节点,这时会有大量数据丢失。
2、且ping的延迟时间小于等于第二个参数,那么master就会拒绝写请求,配置了这两个参数之后,如果发生集群脑裂,原先的master节点接收到客户端的写入请求会拒绝,就可以减少数据同步之后的数据丢失。
3、为了避免这种情况, 在业务应用中使用 EXPIREAT/PEXPIREAT 命令,把数据的过期时间设置为具体的时间点,避免读到过期数据。
4、启动哨兵:启动哨兵进程或服务,让其开始监控主从节点的状态和进行故障转移。 测试和验证:模拟节点故障的情况,观察哨兵是否能够正确地进行故障转移和恢复。
5、避免脑裂现象,用到的一个参数是:discovery.zen.minimum_master_nodes。这个参数决定了要选举一个Master需要多少个节点(最少候选节点数)。默认值是1。
6、同样机房2也不能选出一个Leader,这种情况下整个集群当机房间的网络断掉后,整个集群将没有Leader。而如果过半机制的条件是set.size() = 3,那么机房1和机房2都会选出一个Leader,这样就出现了脑裂。
如何查看redis的sentinel
监控(Monitoring): Sentinel 会不断地检查你的主服务器和从服务器是否运作正常。提醒(Notification): 当被监控的某个 Redis 服务器出现问题时, Sentinel 可以通过 API 向管理员或者其他应用程序发送通知。
首先配置Redis的主从服务器,修改redis.conf文件如下 上述内容主要是配置Redis服务器,从服务器比主服务器多一个slaveof的配置和密码。配置3个哨兵,每个哨兵的配置都是一样的。
我们看下 springboot 项目的客户端如何配置 以访问 哨兵模式的 redis。
查看redis集群状态,确认master(191623100)预期:无法切换 依次关掉两个sentinel,一个redis-server master。
通过 strace 命令查看 socket 的发送和接收数据日志内容,我们基本可以掌握 sentinel/master/slave 这三个角色是怎么联系起来的。