技术标签: 锁 spring boot redisson 分布式 springboot redis
https://github.com/redisson/redisson/tree/master/redisson-spring-boot-starter#spring-boot-starter
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-boot-starter</artifactId>
<version>3.13.1</version>
</dependency>
<!-- redisson -->
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-boot-starter</artifactId>
<version>3.13.1</version>
<exclusions>
<exclusion>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-data-22</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.redisson</groupId>
<!-- for Spring Data Redis v.2.1.x -->
<artifactId>redisson-spring-data-21</artifactId>
<version>3.13.1</version>
</dependency>
<!-- redisson -->
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-boot-starter</artifactId>
<version>3.13.1</version>
<exclusions>
<exclusion>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-data-22</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.redisson</groupId>
<!-- for Spring Data Redis v.2.1.x -->
<artifactId>redisson-spring-data-21</artifactId>
<version>3.13.1</version>
</dependency>
<!-- redis-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
spring:
redis:
redisson:
# 配置单点模式
config: classpath:redisson.yml
jedis:
pool:
max-active: 8 #最大连接数
max-wait: -1 #最大阻塞等待时间(负数表示没限制)
max-idle: 8 #最大空闲
# 单节点配置
singleServerConfig:
# 连接空闲超时,单位:毫秒
idleConnectionTimeout: 10000
# 连接超时,单位:毫秒
connectTimeout: 10000
# 命令等待超时,单位:毫秒
timeout: 3000
# 命令失败重试次数,如果尝试达到 retryAttempts(命令失败重试次数) 仍然不能将命令发送至某个指定的节点时,将抛出错误。
# 如果尝试在此限制之内发送成功,则开始启用 timeout(命令等待超时) 计时。
retryAttempts: 3
# 命令重试发送时间间隔,单位:毫秒
retryInterval: 1500
# # 重新连接时间间隔,单位:毫秒
# reconnectionTimeout: 3000
# # 执行失败最大次数
# failedAttempts: 3
# 密码
password:
# 单个连接最大订阅数量
subscriptionsPerConnection: 5
# 客户端名称
clientName: null
# # 节点地址
address: redis://ip
# 发布和订阅连接的最小空闲连接数
subscriptionConnectionMinimumIdleSize: 1
# 发布和订阅连接池大小
subscriptionConnectionPoolSize: 50
# 最小空闲连接数
connectionMinimumIdleSize: 32
# 连接池大小
connectionPoolSize: 64
# 数据库编号
database: 0
# DNS监测时间间隔,单位:毫秒
dnsMonitoringInterval: 5000
# 线程池数量,默认值: 当前处理核数量 * 2
threads: 0
# Netty线程池数量,默认值: 当前处理核数量 * 2
nettyThreads: 0
# 编码
codec: !<org.redisson.codec.JsonJacksonCodec> {
}
# 传输模式
transportMode : "NIO"
redisson-spring-boot-starter
后@RestController
@RequestMapping("redisson")
public class RedissonController
{
@Autowired
private RedissonClient redissonClient;
@Autowired
private StringRedisTemplate stringRedisTemplate;
private static final String product = "MoonCake";
@RequestMapping("lockAdd")
public void lockAdd() throws Exception
{
//对数据进行加锁
RLock lock = redissonClient.getLock(product);
//加锁
lock.lock();
System.out.println(Thread.currentThread().getName());
String stocks = stringRedisTemplate.opsForValue().get("stock");
int stock = Integer.parseInt(stocks);
if (stock > 0) {
//下单
stock -= 1;
stringRedisTemplate.opsForValue().set("stock", String.valueOf(stock));
System.out.println("扣减成功,库存stock:" + stock);
Thread.sleep(5000);
} else {
//没库存
System.out.println("扣减失败,库存不足");
}
//解锁
lock.unlock();
}
}
文章浏览阅读299次。临邛道士鸿都客,能以精诚致魂魄。为感君王辗转思,遂教方士殷勤觅。排空驭气奔如电,升天入地求之遍。上穷碧落下黄泉,两处茫茫皆不见。忽闻海上有仙山,山在虚无缥缈间。楼阁玲珑五云起,其中绰约多仙子。中有一人字太真,雪肤花貌参差是。金阙西厢叩玉扃,转教小玉报双成。闻道汉家天子使,九华帐里梦魂惊。揽衣推枕起徘徊,珠箔银屏迤逦开。云鬓半偏新睡觉,花冠不整下堂来。1 类中的方法1.1..._python某市新建成了地铁,车票价格如下:1—4站2元,5—7站3元,8—9站4元,10站以上5
文章浏览阅读2.1w次,点赞7次,收藏8次。1,打开gedit,选择菜单栏->编辑(E)->首选项(E)2,进入编辑界面,点击查看按钮,设置显示行号等3,点击编辑器,设置制表符等4,点击字体和颜色,设置字体和颜色5,设置插件6.ok_文本编辑器getedit
文章浏览阅读4.6k次。package.json 文件是用来管理本地安装 npm 包的唯一文件。它描述了当前项目依赖的包的列表,包含项目依赖包的版本,便于项目管理和移植一、创建1、npm init 即可在当前目录创建一个 package.json 文件,跟着步骤选项,手动创建package.json文件2、npm init --yes 可以跳过回答问题步骤,直接生成默认值的 package.json 文件二..._vue package.json中的main
文章浏览阅读464次。缘起本期继续讨论边缘领域里的另一个有意思的东西——语言。正如前文所说,边缘设备是在终端、云端(或者叫后台系统)中出现的一种新形态的设备。它肯定不是终端,因为它比终端能力强,而且倾向于它是为..._边缘计算需要学什么语言
文章浏览阅读2.6k次,点赞4次,收藏7次。Spring项目中:类路径和Web应用的根路径最近在学习Spring书籍中提到:类路径和Web应用的根路径;百度一下,网上并没有给出直接的答案.最后根据百度的结果和自己的理解得出如下直接的答案.类路径:即发布到Tomcat服务器后的ClassPath路径:在IDEA中即resource路径(在Idea中有两个resource目录).Web应用的根路径:顾名思义,即是发布到Tomcat服..._springboot 项目根路径和类路径区别
文章浏览阅读1.3w次。介绍:有一个简单的需求,一个表格点击一个单元格的按钮后,按钮变成进度条。问题:如果只是用一个变量,然后配合v-if使用,一整列都会变成进度条。想法:把那个变量渲染进去列表的每一行。但是…问题又出现了,值变了,但是表格没有被重新渲染。重点:this.$set(this.tableData, index, row),更新表格这一行的值。理解这句代码的意思,后面的可以不看。随便放点前端代码就很长了,不放又清除概况,简单看看吧。直接看el-progress那个标签的附近的,其他的瞅一下知道大概就好。<_elementui刷新table
文章浏览阅读1.9w次,点赞2次,收藏3次。把Maven中央仓库换成阿里云后,下载速度快了很多!配置如下:修改maven根目录下的conf文件夹中的setting.xml文件,内容如下:< !-- 在mirrors 中配置 mirror --><mirrors> <mirror> <id>alimaven</id> <name>aliyun maven</name> <url>
文章浏览阅读2.1k次。最小二乘法拟合直线步骤:(1)分离出目标(如下二值图像中的黑色区域);(2)提取目标边缘坐标;(3)查找所要拟合的边缘坐标;(4)最小二乘法拟合直线。在本文中使用Zernike矩检测目标的亚边缘坐标。根据MATLAB中坐标数据的特点分离出所需坐标数据,这里以水平边缘坐标的纵坐标离散程度不大为查找的条件提取出水平边缘坐标。实验图和结果图如下所示:MATLAB实现:BW=imread("xx.jpg");Coor=zernike7(BW);%查找水平边缘的坐标delta=2;%控制坐标范_matlab拟合矩形
文章浏览阅读971次。高级数据结构实验(Kruskal算法)C语言实现实验目的:1.掌握并查集的合并优化和查询优化2.掌握Kruskal算法3.能够针对实际问题,能够正确选择贪心策略4.能够针对选择的贪心策略,证明算法的正确性5.能够正确分析算法的时间复杂度和空间复杂度实验内容:采用Kruskal算法生成最小生成树,并采用并查集的合并优化和查询优化。实验思路:使用Kruskal算法解决稀疏图解决最小生成树问题效率较高,并使用并查集这种数据结构实现了isConnected()和unionElements()两种_kruskal算法代码c语言实现
文章浏览阅读1.1k次。这里写自定义目录标题webService接口调用的通用方法具体方法如下如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML 图表FLowchart流程图导出与导入导出导入webService接口调用的通用方法webService接口调用的通用方法,一定要注意使用的URL中‘/’ 一定不能多,也一定不能少,否则会出现问题具体方法如下/**调用webS_调用webservice @webparam
文章浏览阅读1w次,点赞2次,收藏18次。最近开发小程序的过程中遇到了这样一个小问题,在wxss文件中通过background设置背景图片,要实现背景图片上显示文字的效果,发现背景图片不显示,设置背景图片的代码如下:.test { width:100rpx; height:30rpx; background:url('../../img/image.png') no-repeat; background-..._微信小程序背景出不来
文章浏览阅读892次。在清晨的八点,走出小区的大门,热气腾腾的市场,毫无规矩的车辆,一脸蜡像的人群,空气中隐藏的愿望,从未被提起的那些故事,那即将失去的时间,即将开始的生活,这个世界变得越难越难理解,如同城里开始变得越来越不如郊区,道路越修越堵,人们却越来越喜欢买车,写字楼盖得越来越多,却还是很难找到工作,淘宝上的二手货竟然会比新货的价格还高,而5块钱的汽油继08年之后竟然真的再次出现了,坐火车基本上..._熊熊作业我去