Springboot中如何使用Redisson實現(xiàn)分布式鎖淺析
前言
在分布式場景下為了保證數(shù)據(jù)最終一致性。在單進程的系統(tǒng)中,存在多個線程可以同時改變某個變量(可變共享變量)時,就需要對變量或代碼塊做同步(lock—synchronized),使其在修改這種變量時能夠線性執(zhí)行消除并發(fā)修改變量。但分布式系統(tǒng)是多部署、多進程的,開發(fā)語言提供的并發(fā)處理API在此場景下就無能為力了。
1. 概述
老話說的好:便宜沒好貨,有價值的商品,即使再貴,也有人會買。
言歸正傳,今天繼續(xù)討論有關(guān)“鎖”的話題,synchronized 和 ReentrantLock 大家應該都非常熟悉了,但這兩個鎖,作用域僅限制于單個Tomcat,如果使用了 Tomcat 集群,這兩個鎖就不管用了。
此時我們就要引入分布式鎖了,分布式鎖的實現(xiàn)方式有很多,可以使用 Mysql 數(shù)據(jù)庫實現(xiàn),也可以使用 Zookeeper 實現(xiàn),當然比較常用的還是使用 Redis 實現(xiàn)。
今天我們就來聊一下基于 Redis 的實現(xiàn)方式 —— Redisson。
Redisson是架設(shè)在redis基礎(chǔ)上的一個Java駐內(nèi)存數(shù)據(jù)網(wǎng)格(In-Memory Data Grid)。充分的利用了Redis鍵值數(shù)據(jù)庫提供的一系列優(yōu)勢,基于Java實用工具包中常用接口,為使用者提供了一系列具有分布式特性的常用工具類。使得原本作為協(xié)調(diào)單機多線程并發(fā)程序的工具包獲得了協(xié)調(diào)分布式多機多線程并發(fā)系統(tǒng)的能力,大大降低了設(shè)計和研發(fā)大規(guī)模分布式系統(tǒng)的難度。同時結(jié)合各富特色的分布式服務(wù),更進一步簡化了分布式環(huán)境中程序相互之間的協(xié)作。
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. 綜述
到此這篇關(guān)于Springboot中如何使用Redisson實現(xiàn)分布式鎖淺析的文章就介紹到這了,更多相關(guān)Springboot用Redisson實現(xiàn)分布式鎖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java利用套接字實現(xiàn)應用程序?qū)?shù)據(jù)庫的訪問
所謂套接字(Socket),就是對網(wǎng)絡(luò)中不同主機上的應用進程之間進行雙向通信的端點的抽象。這篇文章主要介紹了Java利用套接字實現(xiàn)應用程序?qū)?shù)據(jù)庫的訪問,感興趣的可以了解一下2022-09-09
SpringBoot如何配置Controller實現(xiàn)Web請求處理
這篇文章主要介紹了SpringBoot如何配置Controller實現(xiàn)Web請求處理,文中通過圖解示例介紹的很詳細,具有有一定的參考價值,需要的小伙伴可以參考一下2023-05-05
Java中的notyfy()和notifyAll()的本質(zhì)區(qū)別
很多朋友對java中的notyfy()和notifyAll()的本質(zhì)區(qū)別不了解,今天小編抽空給大家整理一篇教程關(guān)于Java中的notyfy()和notifyAll()的本質(zhì)區(qū)別,需要的朋友參考下吧2017-02-02

