前言
在分布式场景下为了保证数据最终一致性。在单进程的系统中,存在多个线程可以同时改变某个变量(可变共享变量)时,就需要对变量或代码块做同步(lock―synchronized),使其在修改这种变量时能够线性执行消除并发修改变量。但分布式系统是多部署、多进程的,开发语言提供的并发处理API在此场景下就无能为力了。
1. 概述
老话说的好:便宜没好货,有价值的商品,即使再贵,也有人会买。
言归正传,今天继续讨论有关“锁”的话题,synchronized 和 ReentrantLock 大家应该都非常熟悉了,但这两个锁,作用域仅限制于单个Tomcat,如果使用了 Tomcat 集群,这两个锁就不管用了。
此时我们就要引入分布式锁了,分布式锁的实现方式有很多,可以使用 Mysql 数据库实现,也可以使用 Zookeeper 实现,当然比较常用的还是使用 Redis 实现。
今天我们就来聊一下基于 Redis 的实现方式 ―― Redisson。
Redisson是架设在redis基础上的一个Java驻内存数据网格(In-Memory Data Grid)。充分的利用了Redis键值数据库提供的一系列优势,基于Java实用工具包中常用接口,为使用者提供了一系列具有分布式特性的常用工具类。使得原本作为协调单机多线程并发程序的工具包获得了协调分布式多机多线程并发系统的能力,大大降低了设计和研发大规模分布式系统的难度。同时结合各富特色的分布式服务,更进一步简化了分布式环境中程序相互之间的协作。
2. Redisson 在 Springboot 中的使用
2.1 引入依赖
<dependency> <groupId>org.redisson</groupId> <artifactId>redisson-spring-boot-starter</artifactId> <version>3.16.3</version> </dependency>
2.2 在 Springboot 配置中配置Redis
支持 Redis单体、Redis哨兵模式 和 Redis集群模式
spring: redis: host: 192.168.1.12 port: 6379 password: zhuifengren
2.3 Demo代码
@Autowired private RedissonClient redissonClient; public void lock() { RLock rLock = redissonClient.getLock("myLock"); log.info("进入了方法"); try { // 加锁,30秒后自动释放锁 rLock.lock(30, TimeUnit.SECONDS); log.info("获得了锁"); Thread.sleep(15000); } catch (Exception ex) { log.error(ex.getMessage(), ex); } finally { // 释放锁 rLock.unlock(); log.info("释放了锁"); } }
3. 综述
到此这篇关于Springboot中如何使用Redisson实现分布式锁浅析的文章就介绍到这了,更多相关Springboot用Redisson实现分布式锁内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://www.cnblogs.com/w84422/p/15387160.html