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

用dedecms 做门户网站国内最好的wordpress主题

用dedecms 做门户网站,国内最好的wordpress主题,前端做网站都要做哪些,网站建设展示型是什么缓存击穿(热点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/421741/

相关文章:

  • 泉州企业网站维护制作wordpress pjax
  • 网站建设平台哪个部门管怎么做带数据库的网站
  • 集团网站建设新闻阿里云服务器价格表
  • 网站左边logo图标怎么做中润建设集团有限公司网站群
  • 初学者学做网站怎么学北京手机响应式网站建设设计
  • 公司网站建设攻略贵州城乡和建设厅网站
  • 网站开发及建设专业做互联网招聘的网站有哪些内容
  • 有没有让人做问卷的网站wordpress不能编辑不能新建
  • pc网站 手机网站 微信网站 上海装潢设计网站
  • 什么是网站建设从哪些方面建设网站有名的app开发公司
  • 网站节约化建设网站做电商销售需要注册吗
  • 转运公司网站建设备案的博客网站可以做别的吗
  • 郑州大学网页设计与网站建设网站后台发文章图片链接怎么做
  • 深圳的网站建设公司推荐子网站建设方案
  • 科技术语沙洋县seo优化排名价格
  • 空包网网站怎么做的网站建设期末试题
  • 制作网站的公司叫什么自己在线制作logo免费图片
  • 太原心诺做网站wordpress token插件
  • 便宜网站建设多少钱谷歌chrome
  • 建设银行网站入口seo排名第一的企业
  • 建设部工程造价管理网站网站备案信息变更
  • 网站开发设计比赛创意设计执行提案
  • 仿网站被封怎么办杭州家具网站建设方案
  • 什么叫网站appwordpress微商货源网
  • 学校网站建设源代码手机版网站开发
  • 二级域名的网站备案石家庄seo网络推广
  • 精品课网站建设网站建设工具有哪些
  • 郑州做网站找赢博科技wordpress结合tornado
  • 网站建设信息稿免费咨询律师在线微信
  • jsp可以做网站首页吗残疾人信息无障碍网站建设