精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分布式鎖的三種實現!

開發 后端 Redis
在 Java 中,使用數據庫、ZooKeeper 和 Redis 都可以實現分布式鎖。但數據庫 IO 操作比較慢,不適合高并發場景;Redis 執行效率最高,但在主從切換時,可能會出現鎖丟失的情況;ZooKeeper 是一個高可用性的分布式協調服務,可以保證數據的強一致性,但是使用 ZooKeeper 需要部署額外的服務,增加了系統復雜度。所以沒有最好的解決方案,只有最合適自己的解決方案。

分布式鎖是一種用于保證分布式系統中多個進程或線程同步訪問共享資源的技術。同時它又是面試中的常見問題,所以我們本文就重點來看分布式鎖的具體實現(含實現代碼)。

在分布式系統中,由于各個節點之間的網絡通信延遲、故障等原因,可能會導致數據不一致的問題。分布式鎖通過協調多個節點的行為,保證在任何時刻只有一個節點可以訪問共享資源,以避免數據的不一致性和沖突。

1、分布式鎖要求

分布式鎖通常需要滿足以下幾個要求:

  1. 互斥性:在任意時刻只能有一個客戶端持有鎖。
  2. 不會發生死鎖:即使持有鎖的客戶端發生故障,也能保證鎖最終會被釋放。
  3. 具有容錯性:分布式鎖需要能夠容忍節點故障等異常情況,保證系統的穩定性。

2、實現方案

在 Java 中,實現分布式鎖的方案有多種,包括:

  • 基于數據庫實現的分布式鎖:可以通過數據庫的樂觀鎖或悲觀鎖實現分布式鎖,但是由于數據庫的 IO 操作比較慢,不適合高并發場景。
  • 基于 ZooKeeper 實現的分布式鎖:ZooKeeper 是一個高可用性的分布式協調服務,可以通過它來實現分布式鎖。但是使用 ZooKeeper 需要部署額外的服務,增加了系統復雜度。
  • 基于 Redis 實現的分布式鎖:Redis 是一個高性能的內存數據庫,支持分布式部署,可以通過Redis的原子操作實現分布式鎖,而且具有高性能和高可用性。

3、數據庫分布式鎖

數據庫的樂觀鎖或悲觀鎖都可以實現分布式鎖,下面分別來看。

(1)悲觀鎖

在數據庫中使用 for update 關鍵字可以實現悲觀鎖,我們在 Mapper 中添加 for update 即可對數據加鎖,實現代碼如下:

<!-- UserMapper.xml -->
<select id="selectByIdForUpdate" resultType="User">
    SELECT * FROM user WHERE id = #{id} FOR UPDATE
</select>

在 Service 中調用 Mapper 方法,即可獲取到加鎖的數據:

@Transactional
public void updateWithPessimisticLock(int id, String name) {
    User user = userMapper.selectByIdForUpdate(id);
    if (user != null) {
        user.setName(name);
        userMapper.update(user);
    } else {
        throw new RuntimeException("數據不存在");
    }
}

(2)樂觀鎖

在 MyBatis 中,可以通過給表添加一個版本號字段來實現樂觀鎖。在 Mapper 中,使用標簽定義更新語句,同時使用 set 標簽設置版本號的增量。

<!-- UserMapper.xml -->
<update id="updateWithOptimisticLock">
    UPDATE user SET
    name = #{name},
    version = version + 1
    WHERE id = #{id} AND version = #{version}
</update>

在 Service 中調用 Mapper 方法,需要傳入更新數據的版本號。如果更新失敗,說明數據已經被其他事務修改,具體實現代碼如下:

@Transactional
public void updateWithOptimisticLock(int id, String name, int version) {
    User user = userMapper.selectById(id);
    if (user != null) {
        user.setName(name);
        user.setVersion(version);
        int rows = userMapper.updateWithOptimisticLock(user);
        if (rows == 0) {
            throw new RuntimeException("數據已被其他事務修改");
        }
    } else {
        throw new RuntimeException("數據不存在");
    }
}

4、Zookeeper 分布式鎖

在 Spring Boot 中,可以使用 Curator 框架來實現 ZooKeeper 分布式鎖,具體實現分為以下 3 步:

  1. 引入 Curator 和 ZooKeeper 客戶端依賴;
  2. 配置 ZooKeeper 連接信息;
  3. 編寫分布式鎖實現類。

(1)引入 Curator 和 ZooKeeper

<dependency>
    <groupId>org.apache.curator</groupId>
    <artifactId>curator-framework</artifactId>
    <version>latest</version>
</dependency>
<dependency>
    <groupId>org.apache.curator</groupId>
    <artifactId>curator-recipes</artifactId>
    <version>latest</version>
</dependency>
<dependency>
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>latest</version>
</dependency>

(2)配置 ZooKeeper 連接

在 application.yml 中添加 ZooKeeper 連接配置:

spring:
  zookeeper:
    connect-string: localhost:2181
    namespace: demo

(3)編寫分布式鎖實現類

@Component
public class DistributedLock {

    @Autowired
    private CuratorFramework curatorFramework;

    /**
     * 獲取分布式鎖
     *
     * @param lockPath   鎖路徑
     * @param waitTime   等待時間
     * @param leaseTime  鎖持有時間
     * @param timeUnit   時間單位
     * @return 鎖對象
     * @throws Exception 獲取鎖異常
     */
    public InterProcessMutex acquire(String lockPath, long waitTime, long leaseTime, TimeUnit timeUnit) throws Exception {
        InterProcessMutex lock = new InterProcessMutex(curatorFramework, lockPath);
        if (!lock.acquire(waitTime, timeUnit)) {
            throw new RuntimeException("獲取分布式鎖失敗");
        }
        if (leaseTime > 0) {
            lock.acquire(leaseTime, timeUnit);
        }
        return lock;
    }

    /**
     * 釋放分布式鎖
     *
     * @param lock 鎖對象
     * @throws Exception 釋放鎖異常
     */
    public void release(InterProcessMutex lock) throws Exception {
        if (lock != null) {
            lock.release();
        }
    }
}

5、Redis 分布式鎖

我們可以使用 Redis 客戶端 Redisson 實現分布式鎖,它的實現步驟如下:

  • 添加 Redisson 依賴
  • 配置 Redisson 連接信息
  • 編寫分布式鎖代碼類

(1)添加 Redisson 依賴

在 pom.xml 中添加如下配置:

<!-- https://mvnrepository.com/artifact/org.redisson/redisson-spring-boot-starter -->
<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson-spring-boot-starter</artifactId>
    <version>3.20.0</version>
</dependency>

(2)配置 Redisson 連接

在 Spring Boot 項目的配置文件 application.yml 中添加 Redisson 配置:

spring:
  data:
    redis:
      host: localhost
      port: 6379
      database: 0
redisson:
  codec: org.redisson.codec.JsonJacksonCodec
  single-server-config:
    address: "redis://${spring.data.redis.host}:${spring.redis.port}"
    database: "${spring.data.redis.database}"
    password: "${spring.data.redis.password}"

(3)編寫分布式鎖代碼類

import jakarta.annotation.Resource;
import org.redisson.Redisson;
import org.redisson.api.RLock;
import org.springframework.stereotype.Service;

import java.util.concurrent.TimeUnit;

@Service
public class RedissonLockService {
    @Resource
    private Redisson redisson;

    /**
     * 加鎖
     *
     * @param key     分布式鎖的 key
     * @param timeout 超時時間
     * @param unit    時間單位
     * @return
     */
    public boolean tryLock(String key, long timeout, TimeUnit unit) {
        RLock lock = redisson.getLock(key);
        try {
            return lock.tryLock(timeout, unit);
        } catch (InterruptedException e) {
            Thread.currentThread().interrupt();
            return false;
        }
    }

    /**
     * 釋放分布式鎖
     *
     * @param key 分布式鎖的 key
     */
    public void unlock(String key) {
        RLock lock = redisson.getLock(key);
        lock.unlock();
    }
}

6、Redis VS Zookeeper

Redis 和 ZooKeeper 都可以用來實現分布式鎖,它們在實現分布式鎖的機制和原理上有所不同,具體區別如下:

  • 數據存儲方式:Redis 將鎖信息存儲在內存中,而 ZooKeeper 將鎖信息存儲在 ZooKeeper 的節點上,因此 ZooKeeper 需要更多的磁盤空間。
  • 鎖的釋放:Redis 的鎖是通過設置鎖的過期時間來自動釋放的,而 ZooKeeper 的鎖需要手動釋放,如果鎖的持有者出現宕機或網絡中斷等情況,需要等待鎖的超時時間才能自動釋放。
  • 鎖的競爭機制:Redis 使用的是單機鎖,即所有請求都直接連接到同一臺 Redis 服務器,容易發生單點故障;而 ZooKeeper 使用的是分布式鎖,即所有請求都連接到 ZooKeeper 集群,具有較好的可用性和可擴展性。
  • 一致性:Redis 的鎖是非嚴格意義下的分布式鎖,因為在多臺機器上運行多個進程時,由于 Redis 的主從同步可能會存在數據不一致的問題;而 ZooKeeper 是強一致性的分布式系統,保證了數據的一致性。
  • 性能:Redis 的性能比 ZooKeeper 更高,因為 Redis 將鎖信息存儲在內存中,而 ZooKeeper 需要進行磁盤讀寫操作。

總之,Redis 適合實現簡單的分布式鎖場景,而 ZooKeeper 適合實現復雜的分布式協調場景,也就是 ZooKeeper 適合強一致性的分布式系統。

強一致性是指系統中的所有節點在任何時刻看到的數據都是一致的。ZooKeeper 中的數據是有序的樹形結構,每個節點都有唯一的路徑標識符,所有節點都共享同一份數據,當任何一個節點對數據進行修改時,所有節點都會收到通知,更新數據,并確保數據的一致性。在 ZooKeeper 中,強一致性體現在數據的讀寫操作上。ZooKeeper 使用 ZAB(ZooKeeper Atomic Broadcast)協議來保證數據的一致性,該協議確保了數據更新的順序,所有的數據更新都需要經過集群中的大多數節點確認,保證了數據的一致性和可靠性。

小結

在 Java 中,使用數據庫、ZooKeeper 和 Redis 都可以實現分布式鎖。但數據庫 IO 操作比較慢,不適合高并發場景;Redis 執行效率最高,但在主從切換時,可能會出現鎖丟失的情況;ZooKeeper 是一個高可用性的分布式協調服務,可以保證數據的強一致性,但是使用 ZooKeeper 需要部署額外的服務,增加了系統復雜度。所以沒有最好的解決方案,只有最合適自己的解決方案。

責任編輯:姜華 來源: Java中文社群
相關推薦

2024-10-29 21:17:25

2024-09-02 22:49:33

2022-05-26 10:27:41

分布式互聯網

2019-11-04 08:38:45

分布式事務主流TCC

2014-04-09 14:59:55

Apache Spar

2024-11-28 15:11:28

2020-03-31 16:13:26

分布式事務方案TCC

2019-06-19 15:40:06

分布式鎖RedisJava

2023-11-27 13:50:00

ELK日志架構

2021-02-28 07:49:28

Zookeeper分布式

2017-01-16 14:13:37

分布式數據庫

2018-04-03 16:24:34

分布式方式

2022-04-08 08:27:08

分布式鎖系統

2017-04-13 10:51:09

Consul分布式

2019-02-26 09:51:52

分布式鎖RedisZookeeper

2021-10-25 10:21:59

ZK分布式鎖ZooKeeper

2023-08-21 19:10:34

Redis分布式

2022-01-06 10:58:07

Redis數據分布式鎖

2023-04-03 10:00:00

Redis分布式

2024-10-09 17:12:34

點贊
收藏

51CTO技術棧公眾號

原创国产精品91| 污视频网站在线免费| 在线免费av资源| 天天超碰亚洲| 欧美日韩精品国产| 91欧美日韩一区| www.狠狠爱| 亚洲国产精品一| 日韩免费视频| 欧美亚洲动漫精品| 久久青青草原| 久久草视频在线| 永久免费精品视频| 一色桃子久久精品亚洲| 国产精品免费久久久久影院| 麻豆精品免费视频| 午夜伦理福利在线| 国产精品久久久久9999吃药| 国产精品高精视频免费| 日韩精品卡通动漫网站| 午夜影院在线播放| 国产精品成人一区二区艾草| 国产亚洲精品美女久久久m| 丝袜美腿小色网| 亚洲精品tv| 国产精品国产三级国产aⅴ中文| 99国产盗摄| 国产一级在线免费观看| 99久久人爽人人添人人澡| 悠悠色在线精品| 成人综合电影| 日操夜操天天操| 欧美日韩导航| 色狠狠综合天天综合综合| 欧美日韩视频在线一区二区观看视频| 欧美三级韩国三级日本三斤在线观看| 欧美成人直播| 3d动漫精品啪啪1区2区免费| 日韩视频在线免费播放| 国产精品一区二区黑人巨大 | 99亚洲国产精品| 久久久久久无码精品大片| 国产成人黄色| 欧美视频你懂的| 在线视频福利一区| 狠狠躁日日躁夜夜躁av| 久久精品欧洲| 日韩中文第一页| 国产人妻精品午夜福利免费| 国产调教在线| 欧美韩国日本综合| 成人免费在线网址| 国产精品suv一区二区| 一区二区三区中文| 亚洲国产高清高潮精品美女| av无码精品一区二区三区| 九七电影韩国女主播在线观看| 国产乱子伦视频一区二区三区| 97视频免费在线观看| xxxx日本黄色| 涩爱av色老久久精品偷偷鲁| 欧美性猛交xxx| 成年人黄色在线观看| 91亚洲欧美| 粉嫩高潮美女一区二区三区 | 亚洲一区久久久| 青青草原国产视频| 久久av导航| 日韩午夜av一区| 久章草在线视频| jizz性欧美| 久久久久99精品一区| 亚洲xxx视频| 精品成人无码久久久久久| 中文字幕一区二区三区乱码图片| 久久手机免费视频| 男人天堂av电影| 精品国产一区二区三区噜噜噜| 精品久久国产老人久久综合| 久久99爱视频| 中国色在线日|韩| 色综合天天性综合| 日本五级黄色片| 永久免费av片在线观看全网站| av在线一区二区三区| 3d精品h动漫啪啪一区二区| www.看毛片| 精品一区二区三区免费| 国产aaa精品| 日韩黄色在线视频| 日韩主播视频在线| 91高清视频免费| 久久精品视频8| 亚洲欧美日韩精品一区二区| 欧美激情在线狂野欧美精品| 波多野结衣家庭教师| 亚洲午夜91| 久久6精品影院| 国产高清视频免费在线观看| 国产欧美日韩影院| 久久精品电影网| 天堂а√在线中文在线鲁大师| 精品一区二区三区的国产在线观看| 这里只有精品久久| 无码少妇精品一区二区免费动态| 久久久五月天| 日韩在线视频观看正片免费网站| 久久精品99久久久久久| 日日骚欧美日韩| 成人高清在线观看| jyzzz在线观看视频| 久久蜜桃av一区二区天堂| 精品欧美国产| 色鬼7777久久| 2022国产精品视频| 青青草综合视频| 日日夜夜天天综合| 欧美影院午夜播放| 中文字幕天堂av| 欧美天堂影院| 另类图片亚洲另类| 久久久999久久久| 日本美女视频一区二区| 国产精品一区二区三区成人| 最近中文在线观看| 成人免费高清在线观看| 久久精品一二三区| 1区2区3区在线视频| 亚洲一区二区偷拍精品| 日韩xxxx视频| 亚洲欧美小说色综合小说一区| 日韩一级成人av| 一二三四在线观看视频| 久久精品久久久| 国产不卡视频在线| 在线免费av片| 国产传媒欧美日韩成人| 国产欧美综合精品一区二区| 免费网站看v片在线a| 伊人性伊人情综合网| xxx国产在线观看| 欧美精品一区二区久久| 国产精品wwwwww| 青青国产在线| 欧美视频中文字幕在线| 亚洲图片综合网| 欧美一区电影| 久久6精品影院| 国产www视频| 久久亚洲欧美国产精品乐播 | 黄色片在线播放| 久久精品日产第一区二区三区高清版| 日韩精品不卡| 色呦呦在线看| 欧美成人女星排行榜| 青娱乐国产盛宴| 高清国产一区二区| 精品人妻大屁股白浆无码| 一区二区三区视频免费视频观看网站 | 免费在线观看黄视频| 精品午夜久久福利影院| 国产91社区| av资源在线看片| 欧美综合在线视频| 精品人妻一区二区乱码| 国产成人ay| 国产精品永久免费视频| 日本三级在线视频| 日韩亚洲欧美在线观看| 国产精品二区一区二区aⅴ| 99re6这里只有精品视频在线观看| 在线观看成人av电影| 亚洲精品一区二区在线播放∴| 日韩av最新在线| 爱爱视频免费在线观看| 国产成a人亚洲精| 免费 成 人 黄 色| 欧美午夜网站| 中文字幕在线看视频国产欧美| 亚洲天堂狠狠干| 一区二区三区日本| 国产ts丝袜人妖系列视频| 欧美精品播放| 91精品久久久久久久| 黄色av免费在线观看| 电影一区二区在线观看| 欧美日韩国产小视频在线观看| 91成人在线观看喷潮蘑菇| 亚洲福利电影| 91精品入口蜜桃| 999精品网| 在线播放国产一区二区三区| 国产三级自拍视频| 国产精品久久久久aaaa樱花| 久久久久亚洲av无码网站| 噜噜噜91成人网| 91社在线播放| 奇米影视777在线欧美电影观看| 国产精品久久久久久久久影视| 国产原创视频在线观看| 日韩精品欧美国产精品忘忧草| 亚洲天堂男人网| 偷拍日韩校园综合在线| 欧美日韩人妻精品一区在线| 久久久久久穴| 9191国产视频| 精品国产一区二区三区av片| 91亚洲精品一区二区| 中老年在线免费视频| 超在线视频97| 番号在线播放| 欧美性受xxxx黑人xyx| 久久久国产精品人人片| 国产91精品一区二区麻豆亚洲| 国产三区在线视频| 国产精品二区影院| 亚洲人成77777| 欧美一级免费| 2020国产精品视频| 美丽的姑娘在线观看免费动漫| 激情久久av一区av二区av三区| 日本黄区免费视频观看| 97精品久久久久中文字幕| 91精品视频国产| 午夜精品剧场| 国产精品一区二区免费| 性国裸体高清亚洲| 欧美国产精品日韩| 天堂中文在线观看视频| 狠狠躁天天躁日日躁欧美| 中文字幕av免费在线观看| 成人妖精视频yjsp地址| 在线观看中文av| 久久99精品国产麻豆婷婷| 免费看a级黄色片| 亚洲综合另类| 91国视频在线| 日韩.com| 99在线免费观看视频| 日韩成人在线电影| 国产精品久久久久久久久久99| 黄色在线观看www| 久久久久久有精品国产| 26uuu亚洲电影在线观看| 久久精品中文字幕| 在线观看免费版| 在线a欧美视频| 午夜在线视频| 日韩亚洲国产中文字幕| 免费av网站观看| 在线观看亚洲成人| www.亚洲激情| 欧美在线制服丝袜| 超碰在线免费97| 精品视频1区2区| 91久久精品无码一区二区| 亚洲v中文字幕| 久久久久久久久福利| 国产福利91精品| 中文在线字幕观看| 成人18视频在线播放| 国产高潮免费视频| 日韩在线高清| 一区二区精品视频| 色999日韩| 在线观看免费黄色片| 久久精品凹凸全集| 成人黄色av播放免费| 亚洲国产伊人| 91|九色|视频| 91精品丝袜国产高跟在线| 国产精品区一区二区三在线播放| 久草在线综合| 日韩国产欧美一区| 羞羞答答成人影院www| 欧美这里只有精品| 免费中文字幕日韩欧美| 香港日本韩国三级网站| 国产成人综合亚洲网站| 精品国产av色一区二区深夜久久 | 久久久999精品| 超碰在线免费公开| 性色av一区二区三区免费| 欧美第一视频| 性视频1819p久久| 惠美惠精品网| 午夜美女久久久久爽久久| 中文不卡1区2区3区| 国产精品一区久久久| 国产精品久久久久久久久久白浆| 日韩欧美一区二区三区四区| 亚洲成人精选| 黄www在线观看| 亚洲精品影视| 国产一区二区片| 久久在线精品| aa视频在线播放| 男人的天堂亚洲一区| 北条麻妃视频在线| 国产精品99久久久久久似苏梦涵 | 欧美日韩中字| 中文视频一区视频二区视频三区| 红桃视频亚洲| 成人亚洲精品777777大片| 成人综合在线视频| a级黄色免费视频| 午夜精品久久久久久久| 亚洲性生活大片| 国产视频精品久久久| 午夜小视频免费| 亚洲精品福利资源站| 少妇高潮一区二区三区69| 色偷偷偷亚洲综合网另类| 国产激情在线播放| 亚洲伊人第一页| 欧美色图国产精品| 黄色一级片播放| 国产69精品久久久久777| 青青草华人在线视频| 欧美性猛交xxxx乱大交3| 乱色精品无码一区二区国产盗| 日韩中文字幕在线视频播放| 伊人久久综合一区二区| 国产欧美一区二区三区另类精品| 亚洲精品成人影院| 一区二区三区视频网| 久久色中文字幕| 天天操天天干视频| 91精品福利视频| 四虎免费在线观看| 欧美激情免费看| 国内不卡的一区二区三区中文字幕 | 成人精品一区二区三区电影免费| 欧美偷窥清纯综合图区| 日韩一级免费看| 亚洲精华国产欧美| 视频区 图片区 小说区| 成人爽a毛片一区二区免费| 亚洲国产精品一区二区久久hs| 日本久久精品电影| 欧美中文在线| 日本精品一区二区三区在线| 希岛爱理av免费一区二区| 亚洲欧洲中文| 狠狠干综合网| 毛毛毛毛毛毛毛片123| 中文字幕综合网| 国产成人精品无码高潮| 欧美久久精品一级黑人c片| 国产高清视频色在线www| 国产一区在线免费| 99亚洲一区二区| 深夜黄色小视频| 国产精品久久久久永久免费观看| 精品少妇theporn| 日韩一级片网站| 欧洲在线视频| 国产精品爽爽爽爽爽爽在线观看| 欧美精品一区二区三区中文字幕| 黄大色黄女片18第一次| ...xxx性欧美| 草逼视频免费看| 午夜精品一区二区三区在线播放| 牛牛精品成人免费视频| 欧美国产亚洲一区| 国产天堂亚洲国产碰碰| 中文字幕欧美在线观看| 亚洲激情久久久| 在线观看福利电影| 日韩aⅴ视频一区二区三区| 麻豆一区二区99久久久久| 亚洲天堂资源在线| 日韩欧美一区二区三区久久| 成人免费黄色网页| 成人啪啪免费看| 亚洲精品影视| 林心如三级全黄裸体| 日韩欧美国产一区二区在线播放| yw视频在线观看| 成人欧美一区二区三区黑人孕妇 | 欧美影院一区二区| 秋霞午夜在线观看| 国产精品免费看一区二区三区| 亚洲一区二区伦理| xxxx国产视频| 色综合咪咪久久| 秋霞影院午夜丰满少妇在线视频| 波多野结衣精品久久| 欧美资源在线| 波多野结衣家庭教师| 日韩精品久久久久久福利| 先锋影音一区二区| 欧美日韩精品在线一区二区| 欧美国产精品v| aaa在线视频| 久久综合网hezyo| 伊人春色精品| 国产免费成人在线| 日韩毛片一二三区| 五月婷婷丁香六月|