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

Java必看:三種分布式鎖的具體實現!

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

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

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

1.分布式鎖要求

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

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

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
相關推薦

2023-09-13 09:52:14

分布式鎖Java

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分布式

2021-11-26 06:43:19

Java分布式
點贊
收藏

51CTO技術棧公眾號

精品无人区一区二区| 久久久资源网| 欧美激情第二页| 欧美xingq一区二区| www.成年人视频| 日韩在线观看视频网站| 首页综合国产亚洲丝袜| 日韩三级成人av网| 麻豆tv在线观看| 台湾佬成人网| 亚洲蜜臀av乱码久久精品| 国产亚洲一区在线播放| 最近中文字幕在线视频| 欧美色123| 国产亚洲精品久久久久久| 永久免费黄色片| 欧美粗大gay| 亚洲黄色小视频| 日韩成人av网站| 亚洲欧美另类一区| 免费的国产精品| 97视频免费看| av成人免费网站| 你微笑时很美电视剧整集高清不卡| 69av一区二区三区| 日韩a在线播放| 伊人春色在线观看| 国产精品色婷婷久久58| 开心色怡人综合网站| 国产av无码专区亚洲av| 日韩av午夜在线观看| 久久久亚洲国产| 黄色录像免费观看| 国产亚洲一区二区三区不卡| 亚洲国产精品久久久久| 欧美国产在线一区| 精品九九久久| 色94色欧美sute亚洲线路一ni| 人人干视频在线| 色呦呦在线视频| 亚洲欧洲av一区二区三区久久| 欧美在线一二三区| 日本国产在线| 91在线观看地址| 春色成人在线视频| 国产精品久久免费| 鲁大师成人一区二区三区| 久久久久久久一区二区| 久久中文字幕无码| 国产精品啊v在线| 欧美成人免费va影院高清| 中文天堂资源在线| 大片网站久久| 日韩亚洲欧美成人| 任我爽在线视频| 凹凸成人精品亚洲精品密奴| 一区二区三区天堂av| 日本精品在线观看视频| 女人av一区| 一区二区av在线| 天堂av网手机版| 成人免费在线播放| xxxx性欧美| 国产精品九九九九九九| 国内自拍一区| 午夜精品在线视频| 亚洲婷婷综合网| 久久精品一区| 国产女人精品视频| 色老头一区二区| 全部av―极品视觉盛宴亚洲| 成人激情视频在线播放| 国产视频www| 福利电影一区二区| 九九九九九九精品| 九色在线视频| 国产精品久久久久久久裸模| 亚洲AV无码成人精品一区| av在线免费观看网址| 亚洲一区二区在线免费观看视频 | 久久av免费| 一区二区成人av| 男人的天堂久久久| 一本久道久久综合婷婷鲸鱼| 国产精品69久久久久| ,亚洲人成毛片在线播放| 国产精品正在播放| 久久综合福利| 黄色一级大片在线免费看产| 亚洲国产色一区| 亚洲综合在线网站| 日韩区一区二| 精品一区二区三区四区| 日本黄区免费视频观看| 亚洲第一黄色| 国产欧美日韩精品在线观看| 后进极品白嫩翘臀在线视频| 久久久www成人免费无遮挡大片| 在线国产精品网| 国产传媒av在线| 欧美日本精品一区二区三区| 日本三级日本三级日本三级极| 精品国产乱码久久久久久果冻传媒 | 国产精品入口福利| 丰满少妇高潮在线观看| 国产蜜臀av在线一区二区三区| 好吊色视频988gao在线观看| 日韩影片中文字幕| 精品国产乱码久久久久久1区2区| 日韩不卡av在线| 9色精品在线| 91欧美精品成人综合在线观看| 亚洲色欧美另类| 亚洲精品视频自拍| 无需播放器的av| 精品国产乱子伦一区二区| 日韩视频免费在线观看| 五月婷婷视频在线| 成人午夜在线免费| 国产卡一卡二在线| 91综合国产| 日韩av影视综合网| 欧美日韩国产精品综合 | 波多野结衣网页| 亚洲人成网77777色在线播放 | 国产精品久久久久久久久久齐齐| 亚洲第一区第一页| 强行糟蹋人妻hd中文| 久久精品噜噜噜成人av农村| 欧洲一区二区在线 | 欧美色videos| 在线播放av网址| 91精品蜜臀一区二区三区在线| 国产精品av在线| 欧美女优在线| 日韩欧美国产黄色| 精品黑人一区二区三区观看时间| 黄色另类av| 国产成人av一区二区三区| 麻豆视频在线免费观看| 欧美男同性恋视频网站| 国产1区2区在线观看| 久久综合亚州| 日本精品一区二区| 综合在线影院| 国产亚洲精品久久久| 最近国语视频在线观看免费播放| 久久在线观看免费| 虎白女粉嫩尤物福利视频| 精品亚洲自拍| 久久人91精品久久久久久不卡| 黄色三级网站在线观看| 亚洲国产成人av网| 五月天激情小说| 国产亚洲毛片| 欧美日韩免费观看一区| 澳门成人av网| 国产香蕉精品视频一区二区三区| 中文人妻av久久人妻18| 久久久www免费人成精品| 欧美日韩在线观看不卡| 99免费精品| 99国产视频| 福利成人导航| 精品亚洲永久免费精品| 香蕉影院在线观看| 国产精品欧美久久久久无广告 | 四虎国产精品免费久久| 久久久久99精品久久久久| 国产手机av在线| 一卡二卡三卡日韩欧美| 波多野结衣有码| 日韩精品色哟哟| 中文字幕中文字幕在线中一区高清| 亚洲男男av| 久久久久久成人精品| 亚洲欧洲国产综合| 欧美午夜免费电影| 污污的视频在线免费观看| 懂色中文一区二区在线播放| 亚洲熟妇av一区二区三区漫画| 自拍视频一区| 成人午夜黄色影院| 17videosex性欧美| 国产一区二区三区视频| 国产熟女一区二区三区四区| 精品免费在线观看| 污污视频网站在线免费观看| 国产xxx精品视频大全| 国产淫片免费看| 希岛爱理av一区二区三区| 粉嫩av四季av绯色av第一区| 日韩不卡免费高清视频| 另类色图亚洲色图| 欧美成人综合在线| 欧美另类videos死尸| 精品久久免费视频| 国产精品成人免费在线| 国产精品成人99一区无码 | 成年人在线视频| 精品美女在线播放| 中文字幕av无码一区二区三区| 亚洲一区二区av电影| 国产精品久久免费观看| 国产91在线观看丝袜| 国产wwwxx| 亚洲人成人一区二区三区| 亚洲精美视频| 日韩伦理一区二区三区| 99国产在线视频| 国产欧美自拍| 国产99久久精品一区二区永久免费 | 日日夜夜精品视频免费观看| 爽好久久久欧美精品| 国产 日韩 欧美在线| 久久精品久久久| 欧美日韩另类综合| 欧美理论电影在线精品| 亚洲一区二区中文字幕| 成人网ww555视频免费看| 韩国一区二区电影| av毛片在线| 日韩专区在线观看| 国产在线视频网| 亚洲精品97久久| 成人av免费播放| 91精品国产综合久久精品app| 无码人妻一区二区三区线| 婷婷中文字幕一区三区| 成人观看免费视频| 中文字幕亚洲一区二区av在线| 欧美偷拍一区二区三区| 91污片在线观看| 国产精品成人99一区无码 | 日韩影视在线| 久久激情五月丁香伊人| 超碰国产在线观看| 国产亚洲免费的视频看| 国产小视频在线| 日韩精品中文字幕久久臀| 人妻一区二区三区免费| 日韩免费电影一区| 性生活免费网站| 欧美大胆人体bbbb| www.激情五月| 欧美刺激午夜性久久久久久久| 午夜精品久久久久久久99老熟妇| 欧美一区二区女人| 在线观看国产黄| 欧美日韩久久久一区| 一本一道人人妻人人妻αv| 91福利资源站| 这里只有久久精品视频| 欧美在线三级电影| 亚洲专区在线播放| 69av一区二区三区| 成人av免费播放| 亚洲精品久久久久久久久久久| 无码精品在线观看| 亚洲视频欧美视频| jizz在线观看中文| 久久久999国产| 动漫一区二区| 热99精品里视频精品| 欧美日韩视频免费观看| 国产精品免费久久久久久| 亚洲成人高清| 懂色av一区二区三区在线播放| 国产91精品入| 日本一区二区三区视频在线观看| 成人3d精品动漫精品一二三| avove在线观看| 亚洲精选成人| 五月婷婷狠狠操| 国产在线视频精品一区| 精品人妻一区二区免费| 久久综合狠狠综合| 欧美巨胸大乳hitomi| 有码一区二区三区| www.伊人久久| 欧美日韩精品免费观看视频| 亚洲AV无码国产精品午夜字幕| 日韩国产高清视频在线| 91成人高清| 高清欧美电影在线| yw.尤物在线精品视频| 91精品免费| 免费看成人哺乳视频网站| 亚洲欧美一二三| 午夜亚洲福利在线老司机| 一级黄色录像在线观看| 成人av在线播放网站| 秋霞网一区二区三区| 亚洲高清不卡在线观看| 中文字幕久久网| 亚洲精品久久久久中文字幕二区| 在线免费av网站| 91精品国产电影| 高清不卡一区| 日本高清久久一区二区三区| 中文字幕亚洲精品乱码| 国产一区二区三区精彩视频 | 在线亚洲观看| 黄色一级片免费播放| 久久久久久一级片| 妺妺窝人体色www聚色窝仙踪| 欧美亚洲图片小说| 丰满肥臀噗嗤啊x99av| 色噜噜国产精品视频一区二区| 爱福利在线视频| 91亚洲国产成人久久精品网站| 久草精品在线| 无码人妻丰满熟妇区96| 国产精品一区二区久久精品爱涩| 在线观看日本中文字幕| 亚洲成av人片一区二区| 国产a级免费视频| 色狠狠av一区二区三区香蕉蜜桃| 欧美另类老肥妇| 国产精品久久精品国产| 亚洲国产精品久久久天堂| 天堂av在线网站| 久久久精品国产免费观看同学| 精品久久免费视频| 日韩欧美一区二区视频| 久久精品视频免费看| 国产精品黄视频| 国产精品三级| 欧美在线观看成人| 成人爱爱电影网址| 国产亚洲欧美精品久久久久久| 在线综合亚洲欧美在线视频| 色哟哟免费在线观看| 国产精品天天狠天天看| av在线不卡顿| 人妻丰满熟妇av无码区app| 久久久五月婷婷| 五月天综合激情| 亚洲国产毛片完整版| 999av小视频在线| 国产精品视频入口| 欧美日韩调教| 久久久久亚洲av成人网人人软件| 亚洲美女视频在线观看| 国产激情无套内精对白视频| 欧美成人精品激情在线观看| 亚洲成人五区| www精品久久| 99久久婷婷国产| 国产一级18片视频| 亚洲男女自偷自拍图片另类| 欧美大胆成人| 亚洲7777| 国产一区二区三区四区五区入口| 美女的奶胸大爽爽大片| 欧美电影免费观看完整版| gogo高清午夜人体在线| 精品综合久久久| 视频一区在线视频| 蜜桃久久精品成人无码av| 欧美吞精做爰啪啪高潮| 麻豆视频网站在线观看| av激情久久| 国产亚洲毛片在线| 日本猛少妇色xxxxx免费网站| 欧美美女一区二区在线观看| 2021国产在线| 精品免费二区三区三区高中清不卡| 欧美亚洲专区| 蜜桃av免费在线观看| 欧美va在线播放| 在线看片国产福利你懂的| 亚洲v国产v| 岛国av在线一区| 91porny九色| 久久九九有精品国产23| 精品国产乱子伦一区二区| 无码日韩人妻精品久久蜜桃| 亚洲人妖av一区二区| 日本免费网站在线观看| 国产精品va在线播放我和闺蜜| 99久久婷婷| 青青草视频播放| 欧美日韩免费高清一区色橹橹| 中文av资源在线| 欧美激情第六页| 精品无人区卡一卡二卡三乱码免费卡 | 不卡av中文字幕| 日本欧美中文字幕| 亚洲国产成人精品女人| 三级黄色片网站| 91精品一区二区三区久久久久久| 国产免费拔擦拔擦8x在线播放| 亚洲精品乱码视频| 成人中文字幕电影| 中文字幕一区二区人妻| 久久久亚洲欧洲日产国码aⅴ| 日韩电影免费在线观看| 亚洲av成人精品一区二区三区 | 四虎成人免费在线|