• 145699

    文章

  • 857

    评论

  • 13

    友链

  • 最近新加了换肤功能,大家多来逛逛吧~~~~
  • 喜欢这个网站的朋友可以加一下QQ群,我们一起交流技术。

Redisson 分布式锁的简单封装 使调用代码更简洁


1. 调用分布式锁的时候, 代码有点繁琐, 每次调用都要写这么一套, 如下

RLock lock = redissonClient.getLock("lock-1");
try {
	boolean tryLock = lock.tryLock(1, 5, TimeUnit.SECONDS);
	if(tryLock) {
		System.out.println("******************** Business ********************");
	}
} catch (InterruptedException e) {
	e.printStackTrace();
} finally {
	if(lock.isHeldByCurrentThread()) {
		lock.unlock();
	}
}

2. 封装一个模板类 RedissonLockTemplate 用来调用锁, 封装一个回调类 TryLockCallback 用来包住执行的业务代码

public interface TryLockCallback<T> {

	T doBusiness();
	
}
public class RedissonLockTemplate {
	private Logger logger = LoggerFactory.getLogger(getClass()); 
	
	private RedissonClient redissonClient;

	public RedissonLockTemplate(RedissonClient redissonClient) {
		this.redissonClient = redissonClient;
	}
	
	public <T> T tryLock(String lockKey, long waitTime, long leaseTime, TimeUnit unit, TryLockCallback<T> action) {
		RLock lock = redissonClient.getLock(lockKey);
		T result = null;
		try {
			boolean tryLock = lock.tryLock(waitTime, leaseTime, unit);
			if(tryLock) {
				result = action.doBusiness();
			}
		} catch (InterruptedException e) {
			logger.error("{} 锁发生中断异常!", lockKey, e);
		} finally {
			if(lock.isHeldByCurrentThread()) {
				lock.unlock();
			}
		}
		return result;
	}
}

3. 在 SpringBoot 项目中使用

@SpringBootConfiguration
public class RedissonConfig {
	
	@Value("${spring.redis.host}")
	private String redisHost;
	@Value("${spring.redis.port}")
	private String redisPort;
	

	@Bean
	public RedissonClient redissonClient() {
		Config config = new Config();
//		config.useSingleServer().setAddress("redis://127.0.0.1:6379");
		config.useSingleServer().setAddress("redis://" + redisHost + ":" + redisPort);
		return Redisson.create(config);
	}
	
	@Bean
	public RedissonLockTemplate redissonLockTemplate() {
		RedissonLockTemplate redissonLockTemplate = new RedissonLockTemplate(redissonClient());
		return redissonLockTemplate;
	}
}
@Autowired
private RedissonLockTemplate redissonLockTemplate;


@RequestMapping("/test")
@ResponseBody
public Integer test() {
	Integer result = redissonLockTemplate.tryLock("lock-1", 1, 5, TimeUnit.SECONDS, new TryLockCallback<Integer>() {
		@Override
		public Integer doBusiness() {
			// 业务代码写在这里
			System.out.println("************** doBusiness *************");
			return 0;
		}
	});
	return result;
}

大家看, 是不是简洁了很多.....


695856371Web网页设计师②群 | 喜欢本站的朋友可以收藏本站,或者加入我们大家一起来交流技术!

0条评论

Loading...


发表评论

电子邮件地址不会被公开。 必填项已用*标注

自定义皮肤 主体内容背景
打开支付宝扫码付款购买视频教程
遇到问题联系客服QQ:419400980
注册梁钟霖个人博客