zoukankan      html  css  js  c++  java
  • redis的缓存穿透,缓存雪崩,持久化方式

    Redis

    redis是一个可进行持久化的内存数据库,可以支持string,list,hsh,set,zet这五种数据类型。

    redis的性能很高(redis的读取速度可以达到11万次每秒,写的速度达到8万次每秒)

    redis【缓存穿透】

         缓存穿透是指去查询一个一定不存在的数据,比如说我一共有100个商品,然后你偏偏去查询第101,102个这些不存在的商品,这个时候我们通常情况下就先回去redis里面去查询,但是redis里面就存在,所以就会去数据库中查询,如果大量的这种请求过来,那么就都落在了数据库上面,而数据库也不存在这样的数据,那么缓存就如同虚设,增加了数据库的压力。

    解决方法:

          为了解决这个问题,我们可以缓存空值,也就是说即便数据库中查询出来的数据不存在,也会缓存空值在reids的缓存中,这样下一次就可以走我们的缓存而不是数据库啦,但是太多的空值会占用我们的缓存的内存空间,导致内存的浪费,我们就通过给它设置一个过期时间比如3分钟,这样过了3分钟后存入的空值就会清空,释放空间,但是这样又出现另外一个问题,就是说如果有人在三分钟内加了一条数据,这个时候就有了第101条数据啦,但是当我们用户去查的时候,走的缓存而缓存中却还是空值,导致缓存中的数据和数据库中的数据不一致,为了解决这个问题我们可以在后台增加数据的时候,同时主动更新缓存中存在的数据,或者去删除缓存中的数据,但这条数据还需再次去数据库中查询。

    redis【缓存雪崩】

        大量的缓存穿透,或者缓存在一段时间内同时失效,发生大量的缓存穿透,所有的查询都落在数据库上,造成了缓存雪崩。

    解决方法:

    1.为不同的key,设置不同的过期时间,让缓存失效的时间点尽量均匀

    2.做双缓存策略。

    A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2,

    A1缓存失效时间设置为短期,A2设置为长期。

    【redis持久化】

    有AOF和RDB两种方式,我们一般使用默认的RDB方式。

    因为它的效率会更高,

    RDB持久化是在指定的时间间隔内将内存中的数据集快照写入磁盘,

    实际操作过程是fork[分]一个子进程,

    先将数据集写入临时文件,

    写入成功后,再替换之前的文件,用二进制压缩存储,这样可以有效防止写入失败到账先前的数据也丢失。

    具体是在redis.conf中配置的,找到save关键字,

    指定每隔多长时间有多少个key发生变化,

    就将其持久化。

    save 900 1

    #在900秒(15分钟)之后,如果至少有1个key发生变化,则dump内存快照。

    save 300 10

    #在300秒(5分钟)之后,如果至少有10个key发生变化,则dump内存快照。

    save 60 10000

     

     

  • 相关阅读:
    linux 添加环境变量(php为例)
    composer install Your requirements could not be resolved to an installable set of packages
    pytesseract 验证码识别
    mac crontab时间断内随机时间执行定时任务
    Mac使用crontab来实现定时任务
    安居客滑动验证码识别
    jQuery图片点击预览遮罩层,再点击关闭效果
    linux系统必学-部分链接
    JavaScript概念总结:作用域、闭包、对象与原型链
    Web前端性能优化全攻略
  • 原文地址:https://www.cnblogs.com/ycq-qiang/p/11139897.html
Copyright © 2011-2022 走看看