精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

久久韩国免费视频| 欧美色视频在线观看| 欧美xxxx黑人又粗又长精品| 成人小视频在线播放| 日韩精品2区| 欧美va亚洲va香蕉在线| 韩国一区二区av| 快射视频在线观看| 成人黄页在线观看| 国产精品美女主播在线观看纯欲| 一起操在线播放| 欧美人与动xxxxz0oz| 欧美日韩不卡一区| 日韩av三级在线| 欧美极品另类| 久久免费的精品国产v∧| 成人一区二区电影| 日韩人妻精品中文字幕| 欧美99久久| 亚洲网站视频福利| 国产精品扒开腿做爽爽爽a片唱戏 亚洲av成人精品一区二区三区 | 日本精品在线播放| 色欲综合视频天天天| 三级在线免费观看| jizz在线观看| 久久中文字幕电影| 国产精品v欧美精品∨日韩| 毛片在线免费播放| 99国产精品| 欧美日韩国产va另类| 男人晚上看的视频| 欧美裸体在线版观看完整版| 日韩电视剧免费观看网站| 国产探花在线观看视频| 国产原创一区| 色激情天天射综合网| 国产av天堂无码一区二区三区| 免费在线看a| 国产精品久久精品日日| 欧美精品二区三区四区免费看视频 | 日本在线观看不卡视频| 欧美洲成人男女午夜视频| 久久国产一级片| 一本精品一区二区三区| 日韩中文字幕精品视频| 亚洲成人黄色av| 最新亚洲精品| 亚洲人成自拍网站| 中文字幕人妻一区二区三区| 午夜视频一区二区在线观看| 在线不卡a资源高清| 色乱码一区二区三区在线| 成人在线网站| 欧美亚洲国产bt| 成人午夜激情av| 成人av集中营| 欧美高清精品3d| 欧美婷婷精品激情| 99热播精品免费| 精品视频一区 二区 三区| 日日干夜夜操s8| 中文字幕日本一区| 欧美一区二区三区不卡| 伊人av在线播放| 国产91精品入| 亚洲欧美另类国产| 色婷婷在线影院| 欧美一区二区三| 日韩视频永久免费观看| 亚洲综合网在线| 亚洲人www| 欧美壮男野外gaytube| 中文字幕精品无码一区二区| 日韩电影免费在线| 国产一区欧美二区三区| 国产毛片毛片毛片毛片| 国产成人av一区二区三区在线| 国产精品一区二区三区精品| 亚洲 美腿 欧美 偷拍| 久久久久久久久久久久久久久99| 亚洲草草视频| av大全在线| 欧美日韩精品国产| 免费一级特黄录像| va天堂va亚洲va影视| 精品国精品国产尤物美女| 黄色正能量网站| 成人高清av| 欧美日韩高清在线观看| 日本中文字幕第一页| 久88久久88久久久| 国产精品二区三区| 国产女人在线观看| 一区二区三区欧美亚洲| 欧美亚洲另类色图| 9999在线精品视频| 日韩hd视频在线观看| 国产又粗又长又黄的视频| 欧美国产91| 日韩免费中文字幕| 99热这里精品| 亚洲国产精品黑人久久久| 大片在线观看网站免费收看| 国精产品一区二区三区有限公司| 日韩一区二区精品葵司在线| 亚洲久久久久久久| 欧美午夜不卡影院在线观看完整版免费| 欧美一级大胆视频| 精品国自产在线观看| 国产亚洲欧美在线| 亚洲色成人www永久在线观看 | 色94色欧美sute亚洲线路一久 | 中文字幕观看视频| 成人福利视频在线| 国产卡一卡二在线| 欧美天堂视频| 亚洲国产成人91精品| 色哟哟一一国产精品| 久久激情久久| 国产一区免费在线| 三级网站视频在在线播放| 在线观看网站黄不卡| 中国极品少妇videossexhd | 欧美裸身视频免费观看| 成人免费一级片| www国产亚洲精品久久麻豆| 看一级黄色录像| 成人黄色免费网站| 亚洲天堂开心观看| 国产精品xxxx喷水欧美| 国产成人免费网站| 亚洲成人动漫在线| 亚洲成人高清| 中文字幕亚洲二区| 中文字幕1区2区3区| 久久毛片高清国产| 国模无码视频一区二区三区| 97品白浆高清久久久久久| 久久久国产成人精品| 在线视频欧美亚洲| 日本一区二区三区四区| 啊啊啊一区二区| 西瓜成人精品人成网站| 91精品成人久久| 三级视频在线看| 亚洲成av人片www| 男人的天堂影院| 一区二区久久| 久久综合久久久| 在线观看网站免费入口在线观看国内 | 欧美肉大捧一进一出免费视频| 欧美精品激情| 国产精品v欧美精品v日韩| 久草免费在线色站| 亚洲高清不卡av| 99久热在线精品996热是什么| 成人免费高清在线观看| 一二三四视频社区在线| 久久香蕉精品香蕉| 国产91|九色| 国产一区二区三区福利| 欧美三级视频在线| 色婷婷粉嫩av| 国产99久久久国产精品潘金网站| 黄色a级片免费看| 欧美综合自拍| 国产精品久久久一区| 色影院视频在线| 日韩亚洲欧美在线| 日韩男人的天堂| 久久亚洲捆绑美女| 孩娇小videos精品| 你懂的亚洲视频| 国产亚洲自拍偷拍| 欧美无毛视频| 久久成人这里只有精品| 免费观看国产视频| 91国偷自产一区二区三区成为亚洲经典 | 日本国产一区二区三区| 国产香蕉在线| 日韩午夜电影av| 狠狠人妻久久久久久综合| 国产精品麻豆久久久| 国产xxx在线观看| 久久成人精品| 9l视频自拍9l视频自拍| 欧美综合精品| 91牛牛免费视频| 阿v视频在线观看| 最近2019免费中文字幕视频三| 国产三级精品在线观看| 精品高清美女精品国产区| 夫妇交换中文字幕| 国产91精品欧美| 国产又黄又猛又粗| 在线欧美视频| 中文字幕久久一区| 欧美五码在线| 91亚洲精品一区| 成人爱爱网址| 欧美日韩福利视频| 自拍视频在线免费观看| 亚洲国产高清福利视频| 一区二区日韩视频| 欧美性猛交xxxx| 九九热国产精品视频| 国产农村妇女毛片精品久久麻豆| 深夜视频在线观看| 奇米精品一区二区三区在线观看 | 久久久久久激情| 国产嫩草影院久久久久| 亚洲av网址在线| 国产精品亚洲专一区二区三区 | 国产乱码精品一区二区三区忘忧草| 亚洲国产精品久久久久婷蜜芽| 欧美激情麻豆| 亚洲春色在线| 国产成人av| 精品国产一区二区三区四区精华| 亚洲精品tv| 国产欧美精品日韩| 小黄鸭精品aⅴ导航网站入口| 亚州成人av在线| 人交獸av完整版在线观看| 色琪琪综合男人的天堂aⅴ视频| 四虎精品在永久在线观看| 日韩色在线观看| 国产免费一区二区三区最新不卡| 欧美中文字幕久久| 少妇太紧太爽又黄又硬又爽 | 中文亚洲av片在线观看| 精品日韩美女的视频高清| 国产亚洲精品女人久久久久久| 国产精品国产自产拍在线| 精品无码在线观看| 久久精品一区二区三区不卡牛牛 | 97视频热人人精品免费| 五月婷婷综合色| 国产一区二区三区电影在线观看| 久久av免费观看| 亚洲美女15p| 美女亚洲精品| 嫩草影视亚洲| 欧洲精品码一区二区三区免费看| 妖精一区二区三区精品视频| 麻豆精品蜜桃一区二区三区| 亚洲成在人线免费观看| 就去色蜜桃综合| 国产一区不卡| 亚洲国产精品一区在线观看不卡| 日本一本不卡| 一区二区91美女张开腿让人桶| 欧美成人自拍| 国产日韩第一页| 欧美一区不卡| 黄色一级片黄色| 亚洲日本视频| 成人三级视频在线播放| 日本欧美在线观看| 九色porny自拍| 国产伦精一区二区三区| 女同性αv亚洲女同志| 成人综合在线观看| avtt香蕉久久| 久久久99精品久久| www.4hu95.com四虎| 中文字幕一区二区三区不卡| 欧美 日韩 国产 一区二区三区| 亚洲综合久久久| 91九色丨porny丨肉丝| 一本一道久久a久久精品 | 中文字幕一区综合| 欧美日本二区| 水蜜桃色314在线观看| 亚洲永久免费精品| 波多野结衣xxxx| 高清成人在线观看| 性少妇bbw张开| 椎名由奈av一区二区三区| 国产一级做a爱免费视频| 日韩欧美精品中文字幕| 国产又黄又粗又猛又爽| 亚洲国内精品在线| av在线电影观看| 欧美激情视频在线免费观看 欧美视频免费一| xxxx在线视频| 国产精品久久久久久久久久新婚| 国产精区一区二区| 蜜桃网站成人| 香蕉综合视频| 69堂免费视频| 国产乱国产乱300精品| 少妇毛片一区二区三区| 亚洲色图19p| 91丝袜一区二区三区| 欧美一区二区三区在| 噜噜噜噜噜在线视频| 美女福利精品视频| 美女日韩欧美| 高清视频一区| 成人综合久久| 国产极品尤物在线| 精品无人码麻豆乱码1区2区| 性欧美丰满熟妇xxxx性久久久| 18欧美乱大交hd1984| 亚洲天堂视频网站| 欧美电影精品一区二区| 中文字幕在线播放| 欧美专区中文字幕| 免费萌白酱国产一区二区三区| 手机成人av在线| 久久在线精品| 熟女人妻在线视频| 亚洲另类春色国产| 中文亚洲av片在线观看| 亚洲欧洲黄色网| av资源一区| 高清日韩一区| 在线精品小视频| 日本中文字幕影院| 欧美激情在线看| 中文字幕在线观看视频网站| 日韩美女视频在线| 成人三级网址| 91九色单男在线观看| 精品久久成人| 久久综合久久色| 91免费视频观看| 永久免费看片在线播放| 精品区一区二区| 制服丝袜在线播放| 国产在线视频91| 色综合天天综合网中文字幕| 成年人在线看片| 2019国产精品| 欧美一级片免费在线观看| 亚洲国产精品久久久久久| 欧洲一区二区三区| 成人av影视在线| 亚洲一级黄色| 成人啪啪18免费游戏链接| 亚洲精品国产无天堂网2021| 国产视频第二页| 蜜臀久久99精品久久久久久宅男 | 日本免费新一区视频| 日韩精品无码一区二区三区久久久| 天天免费综合色| 无码精品人妻一区二区| 性色av一区二区咪爱| 久久1电影院| 毛片在线视频播放| 91在线国内视频| 日本黄色一级视频| 一二美女精品欧洲| av成人免费| 手机成人av在线| 国产999精品久久久久久绿帽| 日本黄色小说视频| 精品国产欧美一区二区| 1区2区3区在线| 欧美凹凸一区二区三区视频| 日韩va欧美va亚洲va久久| eeuss中文字幕| 日韩亚洲欧美在线| 黄色aa久久| 欧美一区二区三区精美影视 | 国产三级国产精品| 91久久精品一区二区| 调教视频免费在线观看| 99re视频在线播放| 国产日韩欧美一区在线| 五月婷婷综合在线观看| 欧美欧美欧美欧美首页| 污污的网站在线免费观看| 久久国产精品久久| 日本伊人色综合网| 欧美黄片一区二区三区| 日韩久久免费视频| 亚洲欧美久久精品| 日本a视频在线观看| 国产午夜久久久久| av中文字幕播放| 青青草99啪国产免费| 欧美高清视频在线观看mv| 亚洲视频天天射| 色呦呦一区二区三区| 成人看av片| 欧美成人dvd在线视频| 狠狠色丁香婷婷综合| 国产精品美女久久久久av爽| 日韩中文字幕国产精品| 欧美美女黄色| 992kp免费看片| 欧美日韩亚洲天堂| 国产黄色在线免费观看| 欧美日韩三区四区| 国产成人av一区二区三区在线| 波多野结衣电车痴汉| 久久久久久网站| 日韩成人免费|