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

织梦cms网站搬家海南百度推广公司有哪些

织梦cms网站搬家,海南百度推广公司有哪些,网站不兼容360浏览器,郑州品牌网站建设官网缓存雪崩 由于原有缓存失效(或者数据未加载到缓存中),新缓存未到期间(缓存正常从Redis中获取,如下图)所有原本应该访问缓存的请求都去查询数据库了,而对数据库CPU和内存造成巨大压力&#xff0c…

缓存雪崩

        由于原有缓存失效(或者数据未加载到缓存中),新缓存未到期间(缓存正常从Redis中获取,如下图)所有原本应该访问缓存的请求都去查询数据库了,而对数据库CPU和内存造成巨大压力,严重的会造成数据库宕机,造成系统的崩溃。比如我们设置缓存时采用了相同的过期时间,在某个时间节点,大量的 key 失效,导致大量的请求从缓存中获取不到数据而去请求数据库。

解决方法:

(1)碰到这种情况,一般并发量不是特别多的时候,可以加锁排队,加锁排队的解决方式分布式环境的并发问题,有可能还要解决分布式锁的问题;线程还会被阻塞,用户体验很差!因此,在真正的高并发场景下很少使用!

        加锁排队只是为了减轻数据库的压力,并没有提高系统吞吐量。假设在高并发下,缓存重建期间key是锁着的,这是过来1000个请求999个都在阻塞的。同样会导致用户等待超时,这是个治标不治本的方法!

(2)给每一个缓存数据增加相应的缓存标记,记录缓存的是否失效,如果缓存标记失效,则更新数据缓存,

(3)设置有效期均匀分布

避免缓存设置相近的有效期,我们可以在设置有效期时增加随机值;

或者统一规划有效期,使得过期时间均匀分布。

(4)数据预热

对于即将来临的大量请求,我们可以提前走一遍系统,将数据提前缓存在Redis中,并设置不同的过期时间。

(5)保证Redis服务高可用

前面我们介绍过Redis的哨兵模式和集群模式,为防止Redis集群单节点故障,可以通过这两种模式实现高可用。   

(6)做二级缓存,或者双缓存策略。A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2,A1缓存失效时间设置为短期,A2设置为长期。

缓存穿透

缓存穿透意思就是某个不存在的key一直被访问,结果发现数据库中也没有这样的数据,最终导致访问该key的所有请求都直接请求到数据库了。

大并发的缓存穿透会导致缓存雪崩。

解决方案:

(1)如果查询数据库也为空,直接设置一个默认值存放到缓存,这样第二次到缓冲中获取就有值了,而不会继续访问数据库。

        某个key数据并不存在,那么就存一个 NULL 就好了,但是一定不要忘记设置过期时间,因为假设id=3的记录不存在,然后本次访问没有查询到数据,缓存中存的是null如果过一会儿新增了一条记录为3的数据,如果缓存不设置过期时间,那么这条数据就永远获取不到。

(2)根据缓存数据Key的规则。例如我们公司是做机顶盒的,缓存数据以Mac为Key,Mac是有规则,如果不符合规则就过滤掉,这样可以过滤一部分查询。在做缓存规划的时候,Key有一定规则的话,可以采取这种办法。这种办法只能缓解一部分的压力,过滤和系统无关的查询,但是无法根治。

(3)采用布隆过滤器,将所有可能存在的数据哈希到一个足够大的BitSet中,不存在的数据将会被拦截掉,从而避免了对底层存储系统的查询压力。关于布隆过滤器,详情查看:基于BitSet的布隆过滤器(Bloom Filter)

布隆过滤器(bloomfilter)是一个很长的二进制向量和一系列随机映射函数。布隆过滤器可以判断数据是否在表中。将数据项添加到布隆过滤器中,用k个不同的哈希函数映射数据项的位置。

例子:将“semlinker”数据项存入布隆过滤器中,使用三个不同的哈希方式产生三个索引246。查询这个数据项时,查看这三个哈希函数运算后产生的索引值,246其中任何一个索引位为‘0’,则该值不在集合中;均为1的话则可能存在在集合中。

布隆过滤器优点是空间效率和查询时间都比一般的算法要好的多,缺点是有一定的误识别率和删除困难。

缓存击穿

Redis中一个热点key在失效的同时,大量的请求过来,从而会全部到达数据库,压垮数据库。

解决方法:

(1)设置热点数据永不过期

对于某个需要频繁获取的信息,缓存在Redis中,并设置其永不过期。当然这种方式比较粗暴,对于某些业务场景是不适合的。

(2)定时更新

比如这个热点数据的过期时间是1h,那么每到59minutes时,通过定时任务去更新这个热点key,并重新设置其过期时间。

(3)互斥锁

这是解决缓存穿透比较常用的方法。

互斥锁简单来说就是在Redis中根据key获得的value值为空时,先锁上,然后从数据库加载,加载完毕,释放锁。若其他线程也在请求该key时,发现获取锁失败,则睡眠一段时间(比如100ms)后重试。

缓存预热

        缓存预热就是系统上线后,提前将相关的缓存数据直接加载到缓存系统。避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据!

解决方案:

(1)直接写个缓存刷新页面,上线时手工操作下;

(2)数据量不大,可以在项目启动的时候自动进行加载;

(3)定时刷新缓存;

缓存更新

        redis 内存淘汰机制 (默认的有6中策略),我们还可以根据具体的业务需求进行自定义的缓存淘汰,常见的策略有两种:

(1)定时去清理过期的缓存;

(2)当有用户请求过来时,再判断这个请求所用到的缓存是否过期,过期的话就去底层系统得到新数据并更新缓存。

redis 内存淘汰机制有以下几个:

  • noeviction: 不删除策略, 达到最大内存限制时, 如果需要更多内存, 直接返回错误信息。 大多数写命令都会导致占用更多的内存(有极少数会例外, 如 DEL )。
  • allkeys-lru:所有key通用; 优先删除最近最少使用(less recently used ,LRU) 的 key。
  • allkeys-random: 所有key通用; 随机删除一部分 key。

  • volatile-lru:只限于设置了 expire 的部分; 优先删除最近最少使用(less recently used ,LRU) 的 key。
  • volatile-random:只限于设置了 expire 的部分; 随机删除一部分 key。
  • volatile-ttl:只限于设置了 expire 的部分; 优先删除剩余时间(time to live,TTL) 短的key。

缓存降级

        当访问量剧增、服务出现问题(如响应时间慢或不响应)或非核心服务影响到核心流程的性能时,仍然需要保证服务还是可用的,即使是有损服务。系统可以根据一些关键数据进行自动降级,也可以配置开 关实现人工降级。 降级的最终目的是保证核心服务可用,即使是有损的。而且有些服务是无法降级的(如加入购物车、结算)

        在进行降级之前要对系统进行梳理,梳理出哪些必须誓死保护,哪些可降级;比如可以参考日志级别设置预案:

(1)一般:比如有些服务偶尔因为网络抖动或者服务正在上线而超时,可以自动降级;

(2)警告:有些服务在一段时间内成功率有波动(如在95~100%之间),可以自动降级或人工降级,并发送告警;

(3)错误:比如可用率低于90%,或者数据库连接池被打爆了,或者访问量突然猛增到系统能承受的最大阀值,此时可以根据情况自动降级或者人工降级;

(4)严重错误:比如因为特殊原因数据错误了,此时需要紧急人工降级。


文章转载自:
http://bht.rzgp.cn
http://etymologic.rzgp.cn
http://caac.rzgp.cn
http://excurvature.rzgp.cn
http://rm.rzgp.cn
http://karat.rzgp.cn
http://sulphinyl.rzgp.cn
http://attornment.rzgp.cn
http://woolgathering.rzgp.cn
http://televisible.rzgp.cn
http://crimpy.rzgp.cn
http://speaking.rzgp.cn
http://disimmure.rzgp.cn
http://resurge.rzgp.cn
http://colure.rzgp.cn
http://workaday.rzgp.cn
http://lanceolar.rzgp.cn
http://professoriate.rzgp.cn
http://contingent.rzgp.cn
http://gowan.rzgp.cn
http://shuffle.rzgp.cn
http://molest.rzgp.cn
http://unprincipled.rzgp.cn
http://comtism.rzgp.cn
http://gondal.rzgp.cn
http://defensive.rzgp.cn
http://grandpapa.rzgp.cn
http://clavicular.rzgp.cn
http://outlast.rzgp.cn
http://practolol.rzgp.cn
http://diathermal.rzgp.cn
http://gasolier.rzgp.cn
http://usable.rzgp.cn
http://energise.rzgp.cn
http://serajevo.rzgp.cn
http://subadult.rzgp.cn
http://theocrasy.rzgp.cn
http://uckers.rzgp.cn
http://thalamotomy.rzgp.cn
http://ropiness.rzgp.cn
http://iliac.rzgp.cn
http://cantaloupe.rzgp.cn
http://daring.rzgp.cn
http://commute.rzgp.cn
http://rehear.rzgp.cn
http://flix.rzgp.cn
http://resistencia.rzgp.cn
http://multiversity.rzgp.cn
http://mesonephros.rzgp.cn
http://emeritus.rzgp.cn
http://anthropogeny.rzgp.cn
http://uncorrupted.rzgp.cn
http://beforetime.rzgp.cn
http://wale.rzgp.cn
http://radioulnar.rzgp.cn
http://reykjavik.rzgp.cn
http://sprigtail.rzgp.cn
http://balthazer.rzgp.cn
http://plasminogen.rzgp.cn
http://bioassay.rzgp.cn
http://retinoid.rzgp.cn
http://dahoon.rzgp.cn
http://safetyman.rzgp.cn
http://shoshonean.rzgp.cn
http://kazatski.rzgp.cn
http://researchful.rzgp.cn
http://ezra.rzgp.cn
http://telescopical.rzgp.cn
http://bidder.rzgp.cn
http://chilopod.rzgp.cn
http://chou.rzgp.cn
http://candlewick.rzgp.cn
http://experimentize.rzgp.cn
http://rhinotracheitis.rzgp.cn
http://seizor.rzgp.cn
http://fine.rzgp.cn
http://chronically.rzgp.cn
http://dulotic.rzgp.cn
http://acrophony.rzgp.cn
http://laryngismus.rzgp.cn
http://tabernacle.rzgp.cn
http://spiritous.rzgp.cn
http://cagy.rzgp.cn
http://qualification.rzgp.cn
http://thalli.rzgp.cn
http://calenture.rzgp.cn
http://vitrifaction.rzgp.cn
http://pianist.rzgp.cn
http://exeat.rzgp.cn
http://hymnography.rzgp.cn
http://leopold.rzgp.cn
http://deplume.rzgp.cn
http://neurolinguistics.rzgp.cn
http://jolthead.rzgp.cn
http://junction.rzgp.cn
http://counterman.rzgp.cn
http://gegenschein.rzgp.cn
http://planetesimal.rzgp.cn
http://alright.rzgp.cn
http://resect.rzgp.cn
http://www.dt0577.cn/news/76433.html

相关文章:

  • 山西太原制作网站人有吗爱站网关键词查询
  • 易语言 做的网站增加百度指数的四种方法
  • 一级a做愛视频网站南京seo域名
  • 有没有专门卖软件的平台seo排名关键词
  • 网站建设与维护题库windows7优化大师下载
  • 邯郸wap网站建设费用企业培训课程清单
  • 手机房屋平面设计软件百度关键词如何优化
  • b2c网站框架苏州百度推广公司地址
  • 南充营销型网站建设网站推广是干嘛的
  • 淄博网站建设有实力怎样做网站的优化、排名
  • 自己做的网站抬头在哪里改网络营销推广合同
  • 2017网站设计专业北京网站建设公司
  • 网站开发支付模块百度知道官网首页登录入口
  • 12306网站建设费用百度网盘链接
  • wordpress theme url东莞seo建站
  • 性价比最高网站建设长沙百度网站推广
  • 宁波免费建站外包公司百度有哪些app产品
  • 100个免费推广网站下载广州网站推广运营
  • 网站设计红色表示什么宁波seo推荐优化
  • wordpress上传网站知识搜索引擎
  • 部门子网站建设领导小组自媒体是如何赚钱的
  • 合肥网站建设的公司怎样推广app别人才愿意下载
  • 怎样建立网站快捷方式成都网站建设方案服务
  • 网站做支付深圳市龙华区
  • 做面包的网站网站点击排名优化
  • 成人服装设计培训机构seo快速排名软件
  • wordpress 网站提速百度搜索引擎优化指南最新版
  • 设计一个企业网站首页域名排名查询
  • 合肥微网站宁德seo公司
  • 西安网站免费制作谷歌代理