91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

怎么用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

鹤壁市| 安达市| 高青县| 阳城县| 临湘市| 平邑县| 枞阳县| 五寨县| 阳原县| 惠水县| 德州市| 乌兰察布市| 疏附县| 屯昌县| 松滋市| 白河县| 霍邱县| 渭南市| 方山县| 东乡县| 来宾市| 松潘县| 恭城| 牙克石市| 慈溪市| 鄂伦春自治旗| 鹤庆县| 卓尼县| 兴安盟| 修水县| 德州市| 莒南县| 铜山县| 普洱| 苗栗市| 凯里市| 齐河县| 顺平县| 盈江县| 平阴县| 疏勒县|