分布式锁 只需要一行注解,Mars-java框架
@RedisLock(key = "自己定义一个key")public int insert(){ return 1;}
这个锁会在事务开启之前获取,在事务提交以后解锁,并且只对MarsBean有效,对API和DAO无效
如果你不需要锁住整个方法,只需要锁一小段代码,那么可以用下面的方式
在MarsBean里面注入MarsRedisLock对象@MarsBean("testService")public class TestService { @MarsWrite("marsRedisLock") private MarsRedisLock marsRedisLock;}
加锁
Boolean haslock = marsRedisLock.lock("自己定义一个key");if(haslock){ 执行加锁后才能执行的代码}
解锁
marsRedisLock.unlock("加锁的时候传入的那个key");
详细说明
无论是用注解还是lock方法,如果没有获取到锁,会等待20秒,20秒内如果能获取到锁,则正常往下执行,20秒内没获取到锁,则直接停止本次操作
lock方法 会返回true和false来表示有无获取到锁
锁的有效时间为20秒,20秒以后会自动解锁
官网http://mars-framework.com/
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。