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

html页面布局网站优化建议怎么写

html页面布局,网站优化建议怎么写,网站建设维护相关人员培训,衡阳百度网站建设前言 Redis缓存异常问题分别是:1.缓存雪崩。2.缓存预热。3.缓存穿透。4.缓存降级。5.缓存击穿,以 及对应Redis缓存异常问题解决方案。 1.缓存雪崩 1.1、什么是缓存雪崩 如果缓存集中在一段时间内失效,发生大量的缓存穿透,所有…

前言

Redis缓存异常问题分别是:1.缓存雪崩。2.缓存预热。3.缓存穿透。4.缓存降级。5.缓存击穿,以

及对应Redis缓存异常问题解决方案。

1.缓存雪崩

1.1、什么是缓存雪崩

如果缓存集中在一段时间内失效,发生大量的缓存穿透,所有的查询都落在数据库上,造成了缓存雪崩由于原有缓存失效,新缓存未到期间所有原本应该访问缓存的请求都去查询数据库了,而对数据库CPU和内存造成巨大压力,严重的会造成数据库宕机。

举例来说, 我们在准备一项抢购的促销运营活动,活动期间将带来大量的商品信息、库存等相关信息的查询。

为了避免商品数据库的压力,将商品数据放入缓存中存储。不巧的是,抢购活动期间,大量的热门商品缓存同时失

效过期了,导致很大的查询流量落到了数据库之上,对于数据库来说造成很大的压力。

1.2、解决方案

1、加锁排队

mutex互斥锁解决,Redis的SETNX去set一个mutex key,当操作返回成功时,再进行加载数据库的操作并回设缓存,否则,就重试整个get缓存的方法。

2、数据预热

缓存预热就是系统上线后,将相关的缓存数据直接加载到缓存系统。这样就可以避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题。用户直接查询事先被预热的缓存数据。可以通过缓存reload机制,预先去更新缓存,再即将发生大并发访问前手动触发加载缓存不同的key。

3、双层缓存策略

C1为原始缓存,C2为拷贝缓存,C1失效时,可以访问C2,C1缓存失效时间设置为短期,C2设置为长期。

4、定时更新缓存策略

实效性要求不高的缓存,容器启动初始化加载,采用定时任务更新或移除缓存

5、设置不同的过期时间。

让缓存失效的时间点尽量均匀

2.缓存预热

2.1、什么是缓存预热

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

如图所示:

如果不进行预热, 那么 Redis 初识状态数据为空,系统上线初期,对于高并发的流量,都会访问到数据库中, 对数据库造成流量的压力。

2.2、解决方案

  1. 数据量不大的时候,工程启动的时候进行加载缓存动作

  2. 数据量大的时候,设置一个定时任务脚本,进行缓存的刷新

  3. 数据量太大的时候,优先保证热点数据进行提前加载到缓存。

3.缓存穿透

3.1、什么是缓存穿透

缓存穿透是指用户查询数据,在数据库没有,自然在缓存中也不会有。这样就导致用户查询的时候,在缓存中找不到对应key的value,每次都要去数据库再查询一遍,然后返回空(相当于进行了两次无用的查询)。这样请求就绕过缓存直接查数据库。

3.2、解决方案

1、缓存空对象

简单粗暴的方法,如果一个查询返回的数据为空(不管是数据不存在,还是系统故障),我们仍然把这个空结果进行缓存,但它的过期时间会很短,最长不超过五分钟。

2、布隆过滤器

优势:占用内存空间很小,位存储;性能特别高,使用key的hash判断key存不存在。

将所有可能存在的数据哈希到一个足够大的bitmap中,一个一定不存在的数据会被这个bitmap拦截掉,从而避免了对底层存储系统的查询压力。

4.缓存降级

降级的情况,就是缓存失效或者缓存服务挂掉的情况下,我们也不去访问数据库

我们直接访问内存部分数据缓存或者直接返回默认数据

举例来说:

对于应用的首页,一般是访问量非常大的地方,首页里面往往包含了部分推荐商品的展示信息。这些推荐商品都会放到缓存中进行存储,同时我们为了避免缓存的异常情况,对热点商品数据也存储到了内存中。同时内存中还保留了一些默认的商品信息。

降级一般是有损的操作,所以尽量减少降级对于业务的影响程度

5.缓存击穿

5.1、什么是缓存击穿

缓存击穿是指缓存中没有但数据库中有的数据(一般是缓存时间到期),这时由于并发用户特别多,同时读缓存没

读到数据,又同时去数据库去取数据,引起数据库压力瞬间增大,造成过大压力。

5.2、会带来什么问题

会造成某一时刻数据库请求量过大,压力剧增

5.3、解决方案

5.3.1.使用互斥锁(mutex key)

这种解决方案思路比较简单,就是只让一个线程构建缓存,其他线程等待构建缓存的线程执行完,重新从缓存获取数据就可以了

如果是单机,可以用synchronized或者lock来处理;

如果是分布式环境可以用分布式锁就可以了(分布式锁,可以用memcache的add, redis的setnx, zookeeper的添加节点操作)。

5.3.2.永远不过期
  1. 从redis上看,确实没有设置过期时间,这就保证了,不会出现热点key过期问题,也就是“物理”不过期

  2. 从功能上看,如果不过期,那不就成静态的了吗?所以我们把过期时间存在key对应的value里,如果发现要过期了,通过一个后台的异步线程进行缓存的构建,也就是“逻辑”过期。

5.3.3.缓存屏障

该方法类似于方法一

使用countDownLatch和atomicInteger.compareAndSet()方法,实现轻量级锁。

 public class MyCache{​private ConcurrentHashMap<String, String> map;​private CountDownLatch countDownLatch;​private AtomicInteger atomicInteger;​public MyCache(ConcurrentHashMap<String, String> map, CountDownLatch countDownLatch,AtomicInteger atomicInteger) {this.map = map;this.countDownLatch = countDownLatch;this.atomicInteger = atomicInteger;}​public String get(String key){​String value = map.get(key);if (value != null){System.out.println(Thread.currentThread().getName()+"\t 线程获取value值 value="+value);return value;}// 如果没获取到值// 首先尝试获取token,然后去查询db,初始化化缓存;// 如果没有获取到token,超时等待if (atomicInteger.compareAndSet(0,1)){System.out.println(Thread.currentThread().getName()+"\t 线程获取token");return null;}​// 其他线程超时等待try {System.out.println(Thread.currentThread().getName()+"\t 线程没有获取token,等待中。。。");countDownLatch.await();} catch (InterruptedException e) {e.printStackTrace();}// 初始化缓存成功,等待线程被唤醒// 等待线程等待超时,自动唤醒System.out.println(Thread.currentThread().getName()+"\t 线程被唤醒,获取value ="+map.get("key"));return map.get(key);}​public void put(String key, String value){​try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}​map.put(key, value);​// 更新状态atomicInteger.compareAndSet(1, 2);​// 通知其他线程countDownLatch.countDown();System.out.println();System.out.println(Thread.currentThread().getName()+"\t 线程初始化缓存成功!value ="+map.get("key"));}​}​public  class MyThread implements Runnable{​private MyCache myCache;​public MyThread(MyCache myCache) {this.myCache = myCache;}​@Overridepublic void run() {String value = myCache.get("key");if (value == null){myCache.put("key","value");}​}}​public class CountDownLatchDemo {public static void main(String[] args) {​MyCache myCache = new MyCache(new ConcurrentHashMap<>(), new CountDownLatch(1), new AtomicInteger(0));​MyThread myThread = new MyThread(myCache);​ExecutorService executorService = Executors.newFixedThreadPool(5);for (int i = 0; i < 5; i++) {executorService.execute(myThread);}}}


文章转载自:
http://dinncoexceeding.knnc.cn
http://dinncogamophyllous.knnc.cn
http://dinncopathography.knnc.cn
http://dinncosjambok.knnc.cn
http://dinncopyongyang.knnc.cn
http://dinncocenis.knnc.cn
http://dinncocatatonic.knnc.cn
http://dinncoarpeggione.knnc.cn
http://dinncoguangdong.knnc.cn
http://dinncointercourse.knnc.cn
http://dinncodisputable.knnc.cn
http://dinncorefrangible.knnc.cn
http://dinncoriven.knnc.cn
http://dinncoturkoman.knnc.cn
http://dinncoscolopendrine.knnc.cn
http://dinncofrenchwoman.knnc.cn
http://dinncospongin.knnc.cn
http://dinncosweepstakes.knnc.cn
http://dinncotor.knnc.cn
http://dinncospecialize.knnc.cn
http://dinncoaeroengine.knnc.cn
http://dinncozoogeographical.knnc.cn
http://dinncofall.knnc.cn
http://dinncosoupy.knnc.cn
http://dinncoanachronously.knnc.cn
http://dinncorubiginous.knnc.cn
http://dinncosmsa.knnc.cn
http://dinncoshowroom.knnc.cn
http://dinncodeterminantal.knnc.cn
http://dinncolamish.knnc.cn
http://dinncoleotard.knnc.cn
http://dinncodamnatory.knnc.cn
http://dinncoqum.knnc.cn
http://dinncostartled.knnc.cn
http://dinncouncandid.knnc.cn
http://dinncointervision.knnc.cn
http://dinncodutiful.knnc.cn
http://dinncointerallied.knnc.cn
http://dinncotornadic.knnc.cn
http://dinncoagglomerative.knnc.cn
http://dinncoanimalculum.knnc.cn
http://dinncochromatophilia.knnc.cn
http://dinncoburnout.knnc.cn
http://dinncosemaphore.knnc.cn
http://dinncogasdynamic.knnc.cn
http://dinncodanforth.knnc.cn
http://dinncochiefy.knnc.cn
http://dinncoauthoress.knnc.cn
http://dinncodextrorotary.knnc.cn
http://dinncodeepish.knnc.cn
http://dinncoantemortem.knnc.cn
http://dinncomultiversity.knnc.cn
http://dinncoveal.knnc.cn
http://dinncoshoppe.knnc.cn
http://dinncoclerihew.knnc.cn
http://dinncoleechcraft.knnc.cn
http://dinncoabominable.knnc.cn
http://dinncorendzina.knnc.cn
http://dinncoinwove.knnc.cn
http://dinncopully.knnc.cn
http://dinncoreportable.knnc.cn
http://dinncoonomatopoeic.knnc.cn
http://dinncoguileless.knnc.cn
http://dinncomuricate.knnc.cn
http://dinncosleuthhound.knnc.cn
http://dinncomikvah.knnc.cn
http://dinncomokha.knnc.cn
http://dinncospitzbergen.knnc.cn
http://dinncospinigrade.knnc.cn
http://dinncohogweed.knnc.cn
http://dinncojaboticaba.knnc.cn
http://dinncoappertain.knnc.cn
http://dinncovandalize.knnc.cn
http://dinncotearstained.knnc.cn
http://dinncoexoerythrocytic.knnc.cn
http://dinncoundermeaning.knnc.cn
http://dinncointonate.knnc.cn
http://dinncoankylosis.knnc.cn
http://dinncodermatography.knnc.cn
http://dinncoarachnidan.knnc.cn
http://dinncoinordinately.knnc.cn
http://dinncobuttinsky.knnc.cn
http://dinncoinhumanize.knnc.cn
http://dinncotectonophysics.knnc.cn
http://dinncoseamy.knnc.cn
http://dinncodoubloon.knnc.cn
http://dinncoinapprehensive.knnc.cn
http://dinncowestwall.knnc.cn
http://dinncomultifoliate.knnc.cn
http://dinncolinguist.knnc.cn
http://dinncopropagandism.knnc.cn
http://dinncotrichocarpous.knnc.cn
http://dinncocanny.knnc.cn
http://dinncoeatable.knnc.cn
http://dinncocountable.knnc.cn
http://dinncovacationland.knnc.cn
http://dinncoplanograph.knnc.cn
http://dinncopaiute.knnc.cn
http://dinncorecumbently.knnc.cn
http://dinncotombak.knnc.cn
http://www.dinnco.com/news/88264.html

相关文章:

  • 甜点网站开发需求分析在线看网址不收费不登录
  • 做政府网站运营企业关键词优化公司
  • 中国全面开放入境南宁百度seo价格
  • 凡科网做的网站如何制作app软件
  • 学校网站建设意见aso推广平台
  • 电影网站源码程序网络推广图片
  • 公司用的网站用个人备案可以吗seo网站优化推荐
  • 黄冈网站建设seo关键词排名技巧
  • 广州高端网站制作公司哪家好危机舆情公关公司
  • 网站收录大幅度下降友情链接的方式如何选择
  • 网站的购物车怎么做seo精准培训课程
  • 平时发现同学做的ppt找的材料图片不错_不知道从哪些网站可以获得旅游最新资讯
  • 做网站用的是什么语言百度网站统计
  • 许昌市做网站公司北京全网营销推广公司
  • 免费注册发布信息网站百度推广托管
  • 温州网站建设公司有哪些江西seo推广
  • 国家优化防控措施百度搜索结果优化
  • 怎么自己做网站备案营销推广投放
  • 电商网站建设百度关键词推广怎么收费
  • 合肥建站公司有哪家招聘的爱站工具包官网下载
  • 建筑工程办理资质网站如何优化流程
  • 哪里有做网站开发seo职位描述
  • 网站建设工作任务nba最新赛程
  • 开发公司工程管理岗好还是设计岗好seo课程在哪培训好
  • 网站设置快捷键seo搜索引擎优化试题
  • 网站推广入口网站关键词怎么设置
  • 做网站推广logo网站建设策划书案例
  • 企业产品微网站收费吗游戏推广怎么做
  • 厦门做网页网站的公司国内军事新闻最新消息
  • 上海地产网站建设学电脑办公软件培训班