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

哪些网站是响应式网站温州关键词优化工具

哪些网站是响应式网站,温州关键词优化工具,欧洲网站后缀,宝安做小程序有推荐吗文章目录前言1、分布式情况下如何加锁2、具体实现过程3、测试3.1 一个服务按照多个端口同时启动3.2 使用jmeter进行压测前言 上一篇实现了单体应用下如何上锁,这一篇主要说明如何在分布式场景下上锁 上一篇地址:加锁 1、分布式情况下如何加锁 需要注意的点是: 在上锁和释放…

文章目录

    • 前言
    • 1、分布式情况下如何加锁
    • 2、具体实现过程
    • 3、测试
      • 3.1 一个服务按照多个端口同时启动
      • 3.2 使用jmeter进行压测

三连哦

前言

上一篇实现了单体应用下如何上锁,这一篇主要说明如何在分布式场景下上锁

上一篇地址:加锁

1、分布式情况下如何加锁

需要注意的点是: 在上锁和释放锁的过程中要保证原子性操作

在这里插入图片描述

在这里插入图片描述

2、具体实现过程

核心是上锁和解锁的过程

关于解锁使用脚本参考:SET key value [EX seconds] [PX milliseconds] [NX|XX]

//上锁过程
String uuid = UUID.randomUUID().toString();
Boolean lock = redisTemplate.opsForValue().setIfAbsent("lock", uuid, 300, TimeUnit.SECONDS);//解锁过程、需要 调用脚本
String script = "if redis.call(\"get\",KEYS[1]) == ARGV[1] then  return redis.call(\"del\",KEYS[1]) else return 0 end";
Long lock1 = (Long) redisTemplate.execute(new DefaultRedisScript<Long>(script, Long.class), Arrays.asList("lock"), uuid);
    public Map<String, List<Catalog2Vo>> getCatalogJsonDbWithSpringCache() {//占分布式锁.redis中占坑String uuid = UUID.randomUUID().toString();Boolean lock = redisTemplate.opsForValue().setIfAbsent("lock", uuid, 300, TimeUnit.SECONDS);Map<String, List<Catalog2Vo>> dataFromDb;if (lock) {System.out.println("加锁成功......");try {//加锁成功...执行业务dataFromDb = getCategoriesDb();} finally {//删除锁String script = "if redis.call(\"get\",KEYS[1]) == ARGV[1] then  return redis.call(\"del\",KEYS[1]) else return 0 end";Long lock1 = (Long) redisTemplate.execute(new DefaultRedisScript<Long>(script, Long.class), Arrays.asList("lock"), uuid);}return dataFromDb;} else {//加锁失败...重试.synchronized  休眠100ms重试System.out.println("加锁失败......");try {Thread.sleep(200);} catch (Exception e) {}//自旋方式return getCatalogJsonDbWithSpringCache();}}

3、测试

3.1 一个服务按照多个端口同时启动

模拟分布式情况、将一个服务按照多个端口同时启动

具体过程

  • 1 首先,点击修改运行配置在这里插入图片描述

  • 2 将你的项目配置的右上角的Allowl parallel run勾上(允许多启动)在这里插入图片描述

  • 3 将你的项目配置复制一份重启个名字,添加上-Dserver.port=端口号
    在这里插入图片描述

在这里插入图片描述

  • 4 启动项目
    在这里插入图片描述

3.2 使用jmeter进行压测

请求的基本配置

在这里插入图片描述

测试情况
模拟的基本前提: redis中没有缓存数据

上锁成功的情况下、 三个服务中只会出现一次查询数据库、其余接口请求从redis中拿取数据.

下方是测试截图、符合预期情况 、上锁成功

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

redis中缓存的数据
在这里插入图片描述

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

相关文章:

  • 在360做网站和百度做网站的区别网站在线预约模板
  • 怎样是做网站临沂google推广
  • 网站备案人授权公众号微官网
  • 某景区网站建设策划书江苏高端网站建设
  • 能支持微信公众号的网站建设如何制作微信图文链接
  • 关于重新建设网站的申请表牡丹江
  • 大学生健康咨询网站建设方案方维服务公司服务范围
  • 产品宣传册设计网站建设网上那些彩票网站可以自己做吗
  • 网站建设 中企动力鄂ICP备美客多电商平台入驻链接
  • 根据网站集约化建设的要求石家庄网站设计公司的别名是
  • 做网站得先注册域名吗免费网页制作平台
  • 网站主体备案什么网站有题目做
  • 给手机开发网站找私人做网站程序费用
  • 企业网站建设总结报告网络营销师在哪里报名考试
  • 帝国cms网站制作网站建设贰金手指科捷6
  • 厦门网站建设和空间网站建设费用写创意
  • 个人做门户网站社交网络推广方法
  • 深夜视频在线免费WordPress全面优化
  • 做快递网站难吗深圳高端网站制作
  • 手机网站免费建设排行盗版小说网站怎么做
  • 网站自适应屏幕alexa排名什么意思
  • 网站运营主管是干什么的做网站的公司哪好
  • 有做企业网站的吗阿克苏网站建设公司
  • 成都网站建设网站建设猎头公司属于什么行业
  • 木蚂蚁网站正在建设中crm和scrm有什么区别
  • 怎样做网站反链有关维护营销型网站建设的方法
  • 重庆网站建设哪家有wordpress 画线不显示不出来
  • 杭州化工网站建设英语不行如何编程做网站
  • 公司网站怎么建站绍兴大明电力建设有限公司网站
  • 酒店网站建设方案策划书导航网址大全