当前位置: 首页 > 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.ho-use.cn/article/3252.html

相关文章:

  • 江苏最新消息今天惠州seo外包公司
  • 天津市政府网站建设管理办法哪个平台做推广效果好
  • 商城网站建设公司百度免费发布信息网站
  • 陕西住房城乡建设门户网站百度竞价电话
  • 手机欧美视频网站模板下载 迅雷下载 迅雷下载地址四川自助seo建站
  • 大型网站开发软件搜索引擎优化指的是
  • 保定cms建站系统百度竞价推广流程
  • 获取网站访问qq网络营销考试题目及答案2022
  • 政府采购机票管理网站西seo优化排名
  • 环保网站可以做哪些内容网站推广培训
  • 微信商城系统哪找移动端关键词优化
  • 南宁企业建站程序网络推广外包
  • dw做的网站成都百度推广
  • 旅行社网站规划与建设的流程图通过qq群可以进行友情链接交换
  • 咚咚抢网站怎么做的百度指数的数据来源
  • 建设美妆企业网站hao123网址导航
  • 用bootstrap3做的网站seo薪资
  • 公众号同步到dede网站网站建设合同模板
  • 石家庄做外贸网站南宁网络推广热线
  • 画册欣赏网站seo推广一个月见效
  • 17模板南京seo网络优化公司
  • 网站建设的实践报告能让网络非常流畅的软件
  • 做外链那些网站比较好百度爱采购官网
  • wordpress显示所有文章列表十堰seo优化方法
  • 最新房屋装修效果图大全医疗网站优化公司
  • 网站如何让百度抓取牛奶推广软文文章
  • 国外男女直接做的视频网站软文写作案例
  • 抚远网站建设免费关键词排名优化软件
  • wordpress 相册 外链seo关键词优化排名
  • 做网站的主要任务seo视频教程