前言
在分布式場景下為了保證數據最終一致性。在單進程的系統中,存在多個線程可以同時改變某個變量(可變共享變量)時,就需要對變量或代碼塊做同步(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