亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用springboot+zookeeper實現分布式鎖

發布時間:2022-03-22 09:06:45 來源:億速云 閱讀:219 作者:iii 欄目:開發技術

本篇內容主要講解“怎么用springboot+zookeeper實現分布式鎖”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么用springboot+zookeeper實現分布式鎖”吧!

InterProcessMutex內部實現了zookeeper分布式鎖的機制,所以接下來我們嘗試使用這個工具來為我們的業務加上分布式鎖處理的功能

zookeeper分布式鎖的特點:1、分布式 2、公平鎖 3、可重入

依賴

<dependency>
   <groupId>org.apache.zookeeper</groupId>
   <artifactId>zookeeper</artifactId>
   <version>3.4.10</version>
</dependency>
<!-- zookeeper 客戶端 -->
<dependency>
   <groupId>org.apache.curator</groupId>
   <artifactId>curator-framework</artifactId>
   <version>2.12.0</version>
</dependency>
<dependency>
   <groupId>org.apache.curator</groupId>
   <artifactId>curator-recipes</artifactId>
   <version>2.12.0</version>
</dependency>
<!-- lombok -->
<dependency>
   <groupId>org.projectlombok</groupId>
   <artifactId>lombok</artifactId>
   <version>1.18.16</version>
   <scope>provided</scope>
</dependency>

本地封裝

這個工具類主要封裝CuratorFramework這個client(連接Zookeeper)

@Slf4j
public class CuratorClientUtil {
    private String zookeeperServer;

    @Getter
    private CuratorFramework client;

    public CuratorClientUtil(String zookeeperServer) {
        this.zookeeperServer = zookeeperServer;
    }

  	// 創建CuratorFrameworkFactory并且啟動
    public void init() {
       // 重試策略,等待1s,最大重試3次
        RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000,3);
        this.client = CuratorFrameworkFactory.builder()
                .connectString(zookeeperServer)
                .sessionTimeoutMs(5000)
                .connectionTimeoutMs(5000)
                .retryPolicy(retryPolicy)
                .build();
        this.client.start();
    }

   // 容器關閉,CuratorFrameworkFactory關閉
    public void destroy() {
        try {
            if (Objects.nonNull(getClient())) {
                getClient().close();
            }
        } catch (Exception e) {
            log.info("CuratorFramework close error=>{}", e.getMessage());
        }
    }
}

配置

@Configuration
public class CuratorConfigration {
    @Value("${zookeeper.server}")
    private String zookeeperServer;
    // 注入時,指定initMethod和destroyMethod
    @Bean(initMethod = "init", destroyMethod = "destroy")
    public CuratorClientUtil curatorClientUtil() {
        CuratorClientUtil clientUtil = new CuratorClientUtil(zookeeperServer);
        return clientUtil;
    }
}

測試代碼

模擬不同客戶端的請求

@Slf4j
@RestController
@RequestMapping("/test")
public class TestController {
    // 注入client工具類
    @Autowired
    private CuratorClientUtil curatorClientUtil;
    // 在zookeeper的/rootLock節點下創建鎖對應的臨時有序節點
    private String rootLock = "/rootLock";

    @GetMapping("/testLock")
    public Object testLock() throws Exception {
        // 獲取當前線程的名字,方便觀察那些線程在獲取鎖
        String threadName = Thread.currentThread().getName();
        InterProcessMutex mutex = new InterProcessMutex(curatorClientUtil.getClient(), rootLock);
        try {
            log.info("{}---獲取鎖start", threadName);
            // 嘗試獲取鎖,最長等待3s,超時放棄獲取
            boolean lockFlag = mutex.acquire(3000, TimeUnit.SECONDS);
            // 獲取鎖成功,進行業務處理
            if (lockFlag) {
                log.info("{}---獲取鎖success", threadName);
                // 模擬業務處理,時間為3s
                Thread.sleep(3000);
            } else {
                log.info("{}---獲取鎖fail", threadName);
            }
        } catch (Exception e) {
            log.info("{}---獲取鎖異常", threadName);
        } finally {
            // 業務處理完成,釋放鎖,喚醒比當前線程創建的節點序號大(最靠近)的線程獲取鎖
            mutex.release();
            log.info("{}---鎖release", threadName);
        }
        return "線程:" + threadName + "執行完成";
    }
}

JMeter測試

我們使用JMeter模擬100個客戶端同時并發的訪問 localhost:8081/test/testLock,相當于100個客戶端爭搶分布式鎖,結果如圖右上角所示,100個請求花了5分6s,每個線程獲取到鎖后業務處理3s,100個線程理想時間為300s(Thread.sleep(3000)),所以運行時間符合。

怎么用springboot+zookeeper實現分布式鎖

怎么用springboot+zookeeper實現分布式鎖

zookeeper每個線程在/rooLock節點下創建的臨時有序節點如下圖,由于是臨時的,所以線程釋放鎖后這些節點也會刪除

怎么用springboot+zookeeper實現分布式鎖

100個線程程序日志打印

怎么用springboot+zookeeper實現分布式鎖

到此,相信大家對“怎么用springboot+zookeeper實現分布式鎖”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

嵊泗县| 保靖县| 渑池县| 海口市| 岑巩县| 雅江县| 寿阳县| 石嘴山市| 东光县| 虎林市| 运城市| 甘泉县| 镇原县| 浦城县| 阜城县| 宜城市| 安远县| 博罗县| 怀柔区| 广河县| 谷城县| 蓝田县| 庆安县| 东安县| 丁青县| 东光县| 盱眙县| 深圳市| 通海县| 神木县| 凤山县| 关岭| 留坝县| 广德县| 青阳县| 莱芜市| 和平县| 邵武市| 饶河县| 井研县| 合肥市|