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

xx单位网站建设方案网站模板间距

xx单位网站建设方案,网站模板间距,对个人做swot分析的网站,网站是由什么组成的缓存击穿(热点key): 部分key(被高并发访问且缓存重建业务复杂的)失效,无数请求会直接到数据库,造成巨大压力 1.互斥锁:可以保证强一致性 线程一:未命中之后,获取互斥锁,再查询数据库重建缓存,写…

缓存击穿(热点key): 部分key(被高并发访问且缓存重建业务复杂的)失效,无数请求会直接到数据库,造成巨大压力

1.互斥锁:可以保证强一致性

      线程一:未命中之后,获取互斥锁,再查询数据库重建缓存,写入缓存,释放锁

      线程二:查询未命中,未获得锁(已由线程一获得),等待一会,缓存命中

互斥锁实现方式:redis中setnx key value:改变对应key的value,仅当value不存在时执行,以此来实现互斥锁,防止出现锁得不到释放,设置有效期

public Shop queryWithMutex(Long id) throws InterruptedException {Shop shop;//实现互斥锁,解决缓存击穿String key=CACHE_SHOP_KEY+id;//1.从redis查询商铺缓存String shopJson=stringRedisTemplate.opsForValue().get(key);//2.判断是否存在,isNotBlank("")也为falseif(StrUtil.isNotBlank(shopJson)){//3.存在,返回商铺对象return JSONUtil.toBean(shopJson,Shop.class);}//判断命中的是否为空值if(shopJson != null && shopJson.isEmpty()){return null;}//4.实现缓存重建String lockKey=LOCK_SHOP_KEY+id;//4.1.获取互斥锁boolean isLock=tryLock("lockKey");//4.2.判断互斥锁是否成功if(!isLock){//4.3.未成功,等待Thread.sleep(50);//递归shop=queryWithMutex(id);}else{//4.4.成功,从mysql数据库中查询shop=getById(id);//5.判断是否存在if(shop==null){//缓存空值,处理缓存穿透stringRedisTemplate.opsForValue().set(key,"",CACHE_NULL_TTL,TimeUnit.MINUTES);return null;}//6.存在,向redis中缓存店铺数据stringRedisTemplate.opsForValue().set(key,JSONUtil.toJsonStr(shop),LOGIN_USER_TTL, TimeUnit.MINUTES);//7.释放互斥锁unlock(lockKey);}//8.返回return shop;}

2.逻辑过期:

      不存TTL,添加上逻辑过期时间,判断逻辑上有没有过期,以此来更新数据

      线程一:查询缓存,逻辑已过期,获取互斥锁,开启新线程,返回过期数据

               新线程:查询数据库并重建缓存,重置逻辑过期时间,释放锁

      线程二:查询未命中,未获得锁(已由线程一获得),返回过期数据

 private boolean tryLock(String key){//尝试获得互斥锁Boolean flag=stringRedisTemplate.opsForValue().setIfAbsent("key","1",LOCK_SHOP_TTL,TimeUnit.SECONDS);return BooleanUtil.isTrue(flag);//通过工具类将其转化为基本类型}private void unlock(String key){//删除锁stringRedisTemplate.delete("key");}

实现互斥锁相关的方法

//线程池,有10个线程private static final ExecutorService CACHE_REBUILD_EXECUTOR= Executors.newFixedThreadPool(10);

创建线程池

public Shop queryWithLogicalExpire(Long id) {//实现逻辑过期,解决缓存击穿(不存在缓存穿透问题)String key=CACHE_SHOP_KEY+id;String lockKey=LOCK_SHOP_KEY+id;//1.从redis查询商铺缓存String shopJson=stringRedisTemplate.opsForValue().get(key);//2.判断是否存在if(StrUtil.isBlank(shopJson)){//3.不存在,返回nullreturn null;}//4.存在,判断是否过期//将Json反序列化成RedisDate对象RedisData redisData=JSONUtil.toBean(shopJson,RedisData.class);Shop shop=JSONUtil.toBean((JSONObject)redisData.getData(),Shop.class);//5.过期if(LocalDateTime.now().isAfter(redisData.getExpireTime())){//6.缓存重建//6.1.获取互斥锁boolean isLock=tryLock(lockKey);//6.2.获取成功if(isLock){//开启新线程CACHE_REBUILD_EXECUTOR.submit(()->{try {saveShopToRedis(id, 20L);}catch(Exception e){throw new RuntimeException(e);}finally {//释放锁unlock(lockKey);}});}//6.3.获取失败return shop;}return shop;}

逻辑删除相关方法

http://www.yayakq.cn/news/886071/

相关文章:

  • 住房和城乡建设部主网站网站验收流程
  • 营销网站建设培训学校10个国内建筑网站
  • 网站横条广告北京网站建设公司报价
  • 云南网站建设营销旅行社网站建设哪家好
  • 多用户商城源码下载147seo采集工具
  • 做网站简单做百度移动网站点击软
  • 设计一套企业网站多少钱免费网站制作
  • 宾利棋牌在哪个网站做的广告wordpress+整合js
  • 南京做网站南京乐识权威WordPress不显示缓存头像
  • 昆明哪有做网站的wordpress 预览 word
  • 用笔记本做网站服务器新网网站
  • 做三角渐变用哪个网站分销平台官网
  • 弄个做网站公司网站关键词怎样修改
  • 网站验收认识电子商务网站建设技术
  • 红杭州网站建设网站上线需要哪些步骤
  • 郑州做网站公司排名移动网站建设动态
  • 哈尔滨网站建设制作费用织梦网站后台视频教程
  • 网站合作推广方案zencart网站管理 1.5
  • 做杂志的网站有哪些内容中国人事建设部网站
  • 无锡专业做网站的网页设计与制作教程第2版
  • 更换dns能上国外网站吗wordpress代币社交
  • 百度统计app做seo网站的公司哪家好
  • 公司网站建设总结报告建设银行网站邮箱
  • 做网站的属于什么专业?网站的功能建设
  • 长沙知名网站js网站变灰色代码
  • 有意思网站推荐珠海关键词优化软件
  • 网站推广渠道有哪些电子商务服务平台
  • 哈尔滨网站建设报价wordpress企业建站流程
  • 网站设计费用明细网站收录不增加
  • 怎么样做一家装修竞标网站网站设计常州