当前位置: 首页 > news >正文

微信公众号网站开发语言便宜建网站

微信公众号网站开发语言,便宜建网站,淘宝客导购网站怎么建设,服装毕业设计代做网站缓存穿透#xff0c;缓存击穿#xff0c;缓存雪崩 缓存穿透处理方案解决方案1 缓存空数据解决方案2 布隆过滤器 缓存击穿处理方案解决方案 1 互斥锁解决方案2 逻辑过期 缓存雪崩处理方案解决方案 1 给不同的key的过期时间设置添加一个随机值#xff0c;降低同一个时段大量ke… 缓存穿透缓存击穿缓存雪崩 缓存穿透处理方案解决方案1 缓存空数据解决方案2 布隆过滤器 缓存击穿处理方案解决方案 1 互斥锁解决方案2 逻辑过期 缓存雪崩处理方案解决方案 1 给不同的key的过期时间设置添加一个随机值降低同一个时段大量key同时过期的概率解决方案 2 如果redis服务宕机可以利用redis一些高可用的方案 比如哨兵模式集群模式解决方案 3 给缓存业务添加降级限流策略 可以利用ngxin或者getway解决方案 4 给业务添加多级缓存 Guava或者caffeine为一级缓存redis为二级缓存 缓存穿透 缓存穿透是指恶意或异常的查询请求导致缓存系统无法命中缓存每次请求都要查询数据库或其他存储后端导致数据库或存储系统压力过大的问题 可能造成的影响数据库负载增加频繁查询不存在的数据会导致数据库负载迅速增加可能导致数据库崩溃或响应变得非常缓慢。 举一个例子 一个get请求api/news/getByid/2 通过这个id查询我们后端会先去redis中查看是否有缓存如果有的话直接从redis中返回就好了如果没有则去查数据库如果数据库中有的话则缓存该数据并且返回 在我们实际上的请求中有可能会出现查询不存在的id的情况在这种情况下我们redis查不到数据导致大量的请求需要进行数据库查询操作可能会造成数据库宕机。 处理方案 解决方案1 缓存空数据 缓存空数据查询返回的数据为空我们后端仍然把这个空结果进行缓存 优点思路比较简单 缺点比较消耗内存可能发生不一致的问题 解决方案2 布隆过滤器 从上图中看就好像一个净水器一样哈哈作用其实有点类似 那么到底是怎么实现过滤的呢其实底层是通过bitmap来实现的而bitmap又是一个以bit为单位的数组数组中每个位置只能存储二进制数0或1例如我们传入一个数据id1那么布隆过滤器就会通过几个hash函数算出相应的值如下图传入id1通过hash1得到值为1通过hash2得到值为3通过hash3得到值为7那么相应位置值都改为1下次再传入数据id1过来我们只需要判断137这三个位置是否为1即可判断该数据是否是空数据当然布隆过滤器也是需要提前预热的。 缺点实现比较复杂存在误判 优点内存占用比较少没有多余的key 讲一下上面提到的误判 在上图的前提下如果此时又传入一个id7通过三个hash函数计算出来的值分别为71118。那么此时bitmap中有5个位置为1分别为1371118然而此时有一个空数据id10它通过hash函数计算出来的值分别为3718那么此时布隆过滤器会认为该数据不是空数据产生一个误判的问题。 缓存击穿 缓存击穿是给某一个key设置了过期时间当key过期的时候恰好这时间点对这个key有大量的并发请求过来这些并发的请求可能会瞬间把DB给压垮 举一个例子 用白话来讲其实就是在设置redis的时候我们设置了热点数据以及热点数据过期时间但是等到热点数据的过期时间到了之后该热点数据还是有多请求打过来那么此时redis中不存在此热点数据的缓存了就会将这些请求全部打在DB上此时就会出现DB还来不及重建redis就被打死的情况 处理方案 解决方案 1 互斥锁 这个流程其实很好懂当线程1进来查询缓存发现未命中后加一把互斥锁然后才查询数据库重建redis缓存如果在重建还未完成的时候有别的线程进来想要查询数据就会被拦截了一直要等到线程1将数据重新写入redis然后释放锁之后才能够拿到。 优点强一致性 缺点性能差 解决方案2 逻辑过期 逻辑过期意味着永不过期。缓存击穿问题产生的原因是某个热点key过期了请求都打到数据库了造成数据库压力过大。因此我们可以提前准备一个不过期的热点key 不设置它的过期时间将这个key保存到redis中这样理论上总能命中redis。那是怎么判断这个key逻辑上过期了答案是这个key的value存储一个过期时间我们判断这个key是否过期的依据就是这个key的value保存的过期时间。 优点高可用性能高 缺点不能保证数据的绝对一致因为无论此数据是否过期它都会直接就返回当前的数据 缓存雪崩 缓存雪崩是指在同一个时段大量缓存的key同时失效或者redis服务宕机了导致大量的请求全部打到数据库 处理方案 解决方案 1 给不同的key的过期时间设置添加一个随机值降低同一个时段大量key同时过期的概率 解决方案 2 如果redis服务宕机可以利用redis一些高可用的方案 比如哨兵模式集群模式 解决方案 3 给缓存业务添加降级限流策略 可以利用ngxin或者getway 解决方案 4 给业务添加多级缓存 Guava或者caffeine为一级缓存redis为二级缓存
http://www.dnsts.com.cn/news/166638.html

相关文章:

  • 网站开发公司职位wordpress添加分类图片
  • 网站未备案被阻断怎么做西安网站设设
  • 企业微网站制作教程湖南建设信誉查询网站
  • 网站推广的技能网络建站流程
  • 婚纱网站php网站建设费做什么科目
  • 网站未授权cas要怎么做专门做网站的公司 南阳
  • 酷炫给公司网站欣赏免费个人简历电子版填写
  • 网站开发 工作职责酒店网站建设方案
  • 网站不备案备案公司网站建设上海找谁
  • 浙江 网站建设上海百姓装潢有限公司
  • 网站正在建设中 图片云南网络推广seo代理公司
  • 网站网址更新了怎么查WordPress飞不起来
  • c 做网站后端最近国际重大新闻事件2022
  • 网站改版 更换服务器 排名丢失在线制作免费生成图片文字
  • 怎么做网站小图标开源官网
  • 做网站云服务器装系统加工平台英语
  • 网站网络推广策略和电子商务网站模板wordpress
  • 如何选择商城网站建设常德网站建设费用
  • 阿里巴巴网站备案号安卓优化大师app下载安装
  • vs2010做网站在线网页视频抓取工具
  • 德江网站建设湖南长沙旅游攻略
  • 南京电商网站开发网片点焊机
  • 中山公众号平台商场网站建设网页设计与制作dw
  • 局门户网站的建设网站上传wordpress
  • flash网站源文件下载微信小程序云开发费用
  • 互联网 网站建设深圳品牌策划培训
  • 如何做网站吸引广告商网站建设客户资料收集清单
  • 深圳带停机坪的别墅网站怎么做推广和优化
  • wordpress迁移器杭州seo哪家好
  • 自己做的视频可以传别的网站去吗建筑工程公司名字起名大全