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

中文字幕1234区| 色播亚洲婷婷| 久久久久久久99| 在线日本制服中文欧美| 欧美色成人综合| 久久久亚洲欧洲日产国码aⅴ| 黄色片子免费看| tube8在线hd| 久久久久久久久久看片| 国产在线观看精品| 日韩无码精品一区二区三区| 久久99免费视频| 欧美军同video69gay| 亚洲熟妇无码一区二区三区导航| 国产中文在线视频| 国产黄色成人av| 浅井舞香一区二区| 久久99久久99精品免费看小说| 亚洲一区二区三区免费| 在线观看成人免费视频| 国产亚洲黄色片| 午夜看片在线免费| 93久久精品日日躁夜夜躁欧美| 国产精品自拍视频| av资源免费观看| 夜间精品视频| 在线视频国产日韩| 蜜臀av粉嫩av懂色av| 久久精品国产福利| 日韩欧美福利视频| 成人免费性视频| 免费在线观看av| 久久久久久久久伊人| 国产99午夜精品一区二区三区| 国产美女www爽爽爽| av成人黄色| 久久99久久99精品免观看粉嫩| 精品无码一区二区三区| 久久精品色综合| 日韩美女天天操| 在线观看日本一区二区| 一个人看的www视频在线免费观看| 日韩理论片一区二区| 精品蜜桃一区二区三区| 国精产品乱码一区一区三区四区| 狠狠色狠狠色综合| 国产精品久久97| 欧美a视频在线观看| 樱桃成人精品视频在线播放| 毛片精品免费在线观看| 日本伦理一区二区三区| 欧美久久综合网| 日韩黄色高清视频| 国产精品无码一区二区三区免费 | 综合久久国产九一剧情麻豆| 欧美精品二区三区四区免费看视频 | 国产女人精品视频| 亚洲 国产 日韩 欧美| 亚洲尤物影院| 欧美中文字幕在线视频| 依依成人综合网| 美女黄网久久| 国产v综合ⅴ日韩v欧美大片| www亚洲视频| 日韩二区三区四区| 国产精品久久网| 一级黄色a毛片| 国内精品国产三级国产a久久| 成人精品网站在线观看| 国产喷水福利在线视频| 国产精品自拍毛片| 粉嫩av免费一区二区三区| 亚洲精品久久久久久久久久久久久久| 国产激情视频一区二区三区欧美| 国产二区一区| 日韩精品福利| 国产欧美日韩不卡免费| 中文字幕人成一区| 欧美xxxx少妇| 欧美午夜激情在线| 色婷婷综合网站| 日韩视频一二区| 亚洲国产成人av在线| av小说在线观看| 清纯唯美亚洲综合一区| 久久亚洲影音av资源网 | 亚洲国产另类av| 亚欧无线一线二线三线区别| 国产在线|日韩| 91 com成人网| 亚洲中文字幕无码av| 欧美日韩第一| 久久综合久中文字幕青草 | 欧美性猛交xxxx乱大交蜜桃 | 国产精品一区在线| 裸模一区二区三区免费| 国产精品秘入口| 亚洲欧美一区二区久久| 欧美大片在线播放| 欧美一区=区三区| 亚洲电影免费观看高清完整版在线| 精品无人区无码乱码毛片国产| 国产精品久久久久久久久妇女| 国产69精品久久久久99| 中文在线免费看视频| 国产成人在线观看| 日日噜噜噜噜夜夜爽亚洲精品| 超碰个人在线| 在线一区二区三区四区五区 | 久久人人爽爽爽人久久久| 亚洲开发第一视频在线播放| 91av久久| 91精品蜜臀在线一区尤物| 亚洲av无码一区二区三区观看| 99热在线成人| 日本伊人精品一区二区三区介绍 | 国产精品原创巨作av| 欧美精品久久久| 婷婷色在线资源| 欧美视频在线一区| 亚洲第九十七页| 中文字幕一区二区精品区| 欧美在线亚洲在线| 狠狠躁夜夜躁av无码中文幕| 国产精品久久久爽爽爽麻豆色哟哟 | 色国产综合视频| 手机免费看av片| 欧美成人久久| 国产一区二区在线播放| 男男激情在线| 亚洲444eee在线观看| 一级做a爱视频| 日韩理论电影| 国产精品www| 青青色在线视频| 亚洲第一成年网| 亚洲av无码久久精品色欲| 久久高清精品| 国产精品一二区| wwwww在线观看免费视频| 精品日韩美女的视频高清| 4438x全国最大成人| 91成人免费| 成人福利网站在线观看11| 999在线视频| 欧美色视频在线| 久久久久亚洲av成人无码电影| 99国产精品| 国产在线欧美日韩| sm捆绑调教国产免费网站在线观看 | 国产97色在线 | 日韩| 欧美激情极品| 91国产精品91| 日本人妻熟妇久久久久久| 亚洲尤物在线视频观看| 在线成人免费av| 欧美成人首页| 不卡一区二区三区视频| 啦啦啦中文在线观看日本| 精品欧美一区二区在线观看| 欧美黄色免费在线观看| 成人h动漫精品| 国产 日韩 亚洲 欧美| 欧美顶级毛片在线播放| 2019亚洲日韩新视频| 天堂av在线播放| 色哟哟一区二区在线观看| 色婷婷av777| 免费在线观看不卡| 中文字幕人成一区| 在线播放一区二区精品视频| 韩剧1988免费观看全集| 色综合久久网女同蕾丝边| 在线观看精品一区| 欧美老熟妇一区二区三区| 大胆亚洲人体视频| 欧洲av无码放荡人妇网站| 精品视频久久| 91免费欧美精品| 草草视频在线| 一区二区三区亚洲| 国产一区二区三区在线观看| 一区二区三区av电影| 亚洲成人日韩在线| 麻豆精品在线播放| 免费看欧美一级片| 夜夜躁狠狠躁日日躁2021日韩| 国产精品一区二区三区久久久 | 亚洲欧美偷拍另类a∨色屁股| 亚洲性图第一页| 狂野欧美一区| 欧洲金发美女大战黑人| 亚洲精品白浆高清| 成人免费网站在线| 筱崎爱全乳无删减在线观看| 色av中文字幕一区| 色婷婷av一区二区三| 欧美午夜精品免费| 日本在线观看视频网站| 国产欧美久久久精品影院| 亚洲区 欧美区| 日欧美一区二区| av片在线免费| 日本不卡二三区| 精品国产乱码一区二区三区四区| 日本中文字幕一区二区| 午夜精品久久久久久久99热浪潮| a天堂中文在线| 日韩av影视在线| 国产乱码久久久久| 在线视频你懂得一区二区三区| 久久国产露脸精品国产| 中文字幕中文字幕一区| 男女黄床上色视频| 成人永久免费视频| 永久免费的av网站| 日韩和欧美的一区| 国产av麻豆mag剧集| 91不卡在线观看| 亚洲精品日韩在线观看| 日韩成人av在线资源| 91精品入口蜜桃| 亚洲图片小说区| 国产精品96久久久久久| 狠狠操一区二区三区| 欧美精品做受xxx性少妇| 中文字幕在线观看日本| 亚洲人成免费电影| 四虎电影院在线观看| 精品久久五月天| av中文字幕第一页| 欧美美女bb生活片| 中文字幕日本视频| 日韩欧美在线观看视频| 日韩激情在线播放| 亚洲第一在线综合网站| 免费又黄又爽又色的视频| 国产精品卡一卡二| 中文字幕黄色网址| 欧美激情在线一区二区三区| japanese中文字幕| www国产成人免费观看视频 深夜成人网| 国产国语老龄妇女a片| 国产999精品久久| wwwww在线观看| 国产高清在线观看免费不卡| 91大神免费观看| 国产美女精品人人做人人爽| 在线播放av中文字幕| 九色|91porny| 激情图片中文字幕| 国产精品18久久久久久久网站| 亚洲一二三不卡| 国产一区二区福利| 中文字幕 欧美 日韩| 丰满亚洲少妇av| 极品白嫩少妇无套内谢| 国产成人精品综合在线观看| 亚洲天堂av网站| 久久综合久久综合久久| 成年人在线免费看片| 国产精品久久久久aaaa| 国产精品三区在线观看| 亚洲一区二区三区在线播放| 91香蕉在线视频| 色综合夜色一区| 中文字幕福利视频| 91麻豆精品国产91久久久久| 亚洲免费成人网| 日韩禁在线播放| aaa在线观看| 久久亚洲精品网站| 九色porny视频在线观看| 国产97在线|日韩| 9999精品| 久久国产精品 国产精品| 欧美天天综合| 九九久久九九久久| 先锋a资源在线看亚洲| 天天爽天天爽夜夜爽| 国产主播一区二区三区| 欧美国产视频一区二区| 老司机福利av| 国产日本欧美一区二区| 一区视频免费观看| 黑人巨大精品欧美一区二区三区| 91视频在线视频| 日韩精品一区二区三区在线观看| 欧美精品a∨在线观看不卡| 久久精品99久久久久久久久| 丁香影院在线| 国产精品免费视频久久久| 免费看一区二区三区| 久久婷婷人人澡人人喊人人爽| 日韩在线精品| 国产女大学生av| 精品亚洲免费视频| 精品无码国产一区二区三区51安| 国产精品你懂的在线欣赏| 精品深夜av无码一区二区老年| 欧洲国产伦久久久久久久| www黄色在线观看| 中文字幕免费国产精品| 9999精品成人免费毛片在线看| 国产精品久久久久久久电影| 黄色网一区二区| 精品91一区二区三区| 老司机精品视频网站| 野战少妇38p| 亚洲欧洲综合另类| 中国女人一级一次看片| 亚洲国语精品自产拍在线观看| 好了av在线| 国产精品吊钟奶在线| 私拍精品福利视频在线一区| 一级黄色片播放| 免费观看在线色综合| 亚洲综合网在线观看| 午夜在线电影亚洲一区| www.好吊色| 久久久av一区| 国产精品原创视频| 欧美色播在线播放| 免费污网站在线观看| 亚洲影院久久精品| 91成人国产综合久久精品| 亚洲欧美在线磁力| 美女视频在线免费| 国产精品精品软件视频| 亚洲老妇激情| 亚洲精品永久视频| 国产精品免费aⅴ片在线观看| 亚洲久久在线观看| 日韩av网址在线| 国产在线拍揄自揄拍视频 | 中文字幕网址在线| 亚洲欧美国产日韩天堂区| 狠狠操一区二区三区| 国产精品久久亚洲| 狠狠噜噜久久| 精品国产一二区| 亚洲激情综合网| jizz中国少妇| 美女扒开尿口让男人操亚洲视频网站| 欧美成人免费全部网站| 亚洲午夜精品福利| 久久国产精品第一页| 一级片黄色录像| 欧美日韩不卡一区| 色三级在线观看| 国产日本欧美一区二区三区在线| 精品freesex老太交| 春日野结衣av| 久久久精品免费免费| 极品国产91在线网站| 国产一区二区免费| 久久亚洲国产精品尤物| 色香蕉在线观看| 国产精品小仙女| 日本五十路女优| 日韩精品视频在线免费观看| 欧美人与禽猛交乱配| 国产伦理一区二区三区| 国产欧美日韩综合一区在线播放 | 国产又大又粗又长| 欧美成人精品一区二区| 97久久综合区小说区图片区| 久久久久久久久久久99| 久久免费视频色| 伊人影院中文字幕| 久99九色视频在线观看| 美女主播精品视频一二三四| 激情内射人妻1区2区3区 | 日韩风俗一区 二区| 老司机成人影院| 亚洲午夜精品福利| 岛国精品在线播放| 中文字幕在线播| 久久福利视频网| 奇米777国产一区国产二区| 韩国中文字幕av| 亚洲免费在线看| 五月天婷婷在线观看| 国产精品免费观看在线| 中文字幕人成人乱码| 亚洲黄色在线网站| 欧美日韩国产另类不卡| 菠萝蜜视频在线观看www入口| 免费99视频| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲精品在线观看av| 亚洲色图13p| 亚洲va欧美va人人爽成人影院| 熟女少妇在线视频播放| 国产精品久久久久久久浪潮网站| 性猛交xxxx乱大交孕妇印度| 国产成人激情小视频| 国模大胆一区二区三区| 日本少妇高潮喷水xxxxxxx| 欧美一卡二卡在线观看|