redis中什么是穿透与雪崩

发布时间:2021-07-26 16:49:57 作者:Leah
来源:亿速云 阅读:132

这期内容当中小编将会给大家带来有关redis中什么是穿透与雪崩,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

redis穿透与雪崩?

  1.穿透:

  理解:当redis作用于数据缓存的时候,缓存的数据来源于db,而当由于key在redis中未获取到value时,则逻辑代码会从数据库中获取value,这种现象叫做缓存穿透。

  若存在大量key穿过缓存,从db获取value,则会导致数据库压力剧增,甚至瘫痪。

  方案:a.当出现大量无效key时,会从数据库获取value,使用分布式互斥锁对loaddb进行控制。

  b.对请求进行验证,判断是否是有效的key,比如布隆过滤器。

  c.无论key是否取到值,直接返回null。对不太稳定的缓存设置过期时间,如果缓存过期,异步起一个线程从db中获取数据。

  比较:待补充

  2。雪崩:

  理解:redis服务器宕机

  方案:redis集群,主从复制,哨兵模式,redis-cluster

  比较:

  主从复制:读写分离,一旦主机宕机,需要手动进行从机升级,并且容易出现短时间无法写的问题

  哨兵模式:完善读写分离的技术,实现当主机宕机后,自动进行master选举,但数据集中在master中,当master压力过大,很难扩容,通过哨兵+主从复制可以实现redis的高可用,但

  很难实现高并发即分散服务器压力,在对并发量要求不大,推荐使用

  redis-cluster:可实现高可用,高并发,扩容,缩容,maseter选举,在高并发情况下,首选cluster搭建redis集群。

  ##redis主从复制与哨兵模式搭配使用:前者提供高可用,后者提供master选举

  ##redis-cluster=主从复制+哨兵模式+高并发+可扩展。

  1.下载redis

  2.安装gcc执行make命令安装redis

  主从复制:

  启动多个redis,slaveofipport设置master,inforeplication查看redis主从信息

  注意项:1.当master存在密码是slave必须配置文件masterauth设置主机的密码,或者使用configsetmasterauth手动设置密码,不然即使slaveof执

  行成功,master-link-status显示为down,设置完masterauth密码后则显示up。

  2.当主从复制,master宕机,必须手动切换slave为master不然从机不会进行master选举,从机master-link-status变成down,会一直等待master启动,master-link-

  status恢复成up

  3.master默认可写可读,slave默认只读,可以修改slave-read-onlyyes:只读no:读写

  哨兵模式:master宕机自动选举master

  注意项:master宕机重启后会作为slave自动同步到选举后的master上,大件事master和slave密码要保持一致,不然选举后将slave切换成maseter会因此失败。

  cluster集群:密码也需要保持一致,而且需要修改/usr/local/share/gems/gems/redis-3.3.3/lib/redis/client.rb

  (https://img2018.cnblogs.com/blog/1909126/201912/1909126-20191229210642240-329425897.png)修改成正确的密码即可

  cluster:每个key通过CRC16(key)%16384来决定放置哪个槽,共有16384个槽被分配到不同的master中(slave中是没有分配曹的),从而将key放入对应的master中,当master

  宕机,其slave会升级成为master,并将原master的曹与数据转移到新的master上。

  扩容:就是添加新的master-slave让后将其他master的槽分摊给新家的master即可,槽中的数据也会随之转移。

  缩容:相反。

  命令:查看集群节点

  clusternodes

  查看key对应的slot

  clusterkeyslotkey

  查看slot和节点的对应关系

  clusterslots

上述就是小编为大家分享的redis中什么是穿透与雪崩了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. Redis高级应用解析:缓存穿透、击穿、雪崩
  2. redis中缓存穿透击穿雪崩如何解决

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

redis

上一篇:MSSQL 中怎么加密存储过程

下一篇:Docker中怎么利用Consul集群实现一个服务发现功能

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》