真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

分布式之Zookeeper一(分布式鎖與Zookeeper集群)

說(shuō)到分布式開(kāi)發(fā),不得不說(shuō)的就是zookeeper了;zookeeper官網(wǎng)說(shuō)到Apache ZooKeeper致力于開(kāi)發(fā)和維護(hù)可實(shí)現(xiàn)高度可靠的分布式協(xié)調(diào)的開(kāi)源服務(wù)器。那么zk作為一個(gè)協(xié)調(diào)者的存在,是分布式比不可少的一部分。廢話不多說(shuō),直接上干貨

成都創(chuàng)新互聯(lián)擁有一支富有激情的企業(yè)網(wǎng)站制作團(tuán)隊(duì),在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)深耕十載,專業(yè)且經(jīng)驗(yàn)豐富。十載網(wǎng)站優(yōu)化營(yíng)銷經(jīng)驗(yàn),我們已為上1000+中小企業(yè)提供了網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)解決方案,按需求定制制作,設(shè)計(jì)滿意,售后服務(wù)無(wú)憂。所有客戶皆提供一年免費(fèi)網(wǎng)站維護(hù)!

Zookeeper(https://zookeeper.apache.org/)的安裝包可以直接在官網(wǎng)上獲取,https://zookeeper.apache.org/doc/current/zookeeperStarted.html這里有Zookeeper的一些常用的簡(jiǎn)單命令,我們可以嘗試著去試試它。

下面來(lái)說(shuō)分布式鎖,它用到的場(chǎng)景;比如:我們常說(shuō)的驚群效應(yīng)、Zookeeper集群爭(zhēng)先讀取緩存等。這里可能有人提到用redis實(shí)現(xiàn)的分布式鎖,其實(shí)對(duì)比redis和Zookeeper的官網(wǎng)敘述,我們就能清晰的發(fā)現(xiàn):Zookeeper比Redis更適合去做分布式鎖。Zookeeper的擔(dān)保第一條就是它的順序性和一致性,其次是它的原子性。大家也可以詳細(xì)的去了解一下。再分清楚這些之后,我們可以試著思考下Zookeeper它是怎么去實(shí)現(xiàn)的分布式鎖?根據(jù)什么去實(shí)現(xiàn)的?

可以想到如何獲取到Zookeeper的每個(gè)節(jié)點(diǎn)以及子節(jié)點(diǎn)變化,Zookeeper的Watch機(jī)制充分的實(shí)現(xiàn)了這一點(diǎn)。通過(guò)Watch機(jī)制可以清晰的監(jiān)聽(tīng)到Zookeeper的每個(gè)節(jié)點(diǎn)的變化。自然而然的這里也要用到Zookeeper的第三方客戶端。Zookeeper的第三方客戶端有兩個(gè);一個(gè)是zkclient、一個(gè)是curator。在curator中它自己已經(jīng)實(shí)現(xiàn)了分布式鎖,感興趣的可以去看看它的實(shí)現(xiàn)源碼。

在第三方客戶端連接到Zookeeper之后,就可以開(kāi)始實(shí)現(xiàn)分布式鎖了。鎖的排他性、堵塞性、可重入性。排他性zk默認(rèn)就實(shí)現(xiàn)了,zk的節(jié)點(diǎn)必須是唯一的。分布式鎖采用Zookeeper的臨時(shí)順序節(jié)點(diǎn)來(lái)實(shí)現(xiàn),首先獲取鎖,創(chuàng)建一個(gè)Zookeeper的臨時(shí)順序節(jié)點(diǎn);然后需要一個(gè)柵欄(CountDownLatch),確保所有人都拿到自己的編號(hào),即在同一起跑線上。然后開(kāi)始搶鎖,給一個(gè)發(fā)令槍(CountDown)。然后搶到鎖的就去執(zhí)行自己的業(yè)務(wù),watch再次監(jiān)聽(tīng)節(jié)點(diǎn)數(shù)據(jù)變化,然后請(qǐng)求線程去進(jìn)行阻塞等待,接下來(lái)再刪除節(jié)點(diǎn),釋放鎖。

public boolean tryLock() {

        if(currentPath.get() == null || !client.exists(currentPath.get())) {
            String node = client.createEphemeralSequential(LockPath+"/", "locked");
            currentPath.set(node);
        }

        List children =client.getChildren(LockPath);
        // 排序list
        Collections.sort(children);

        // 判斷當(dāng)前節(jié)點(diǎn)是否是最小的
        if(currentPath.get().equals(LockPath+"/"+children.get(0))) {
            return true;
        }else {

            int curIndex = children.indexOf(currentPath.get().substring(LockPath.length() + 1));
            String bnode = LockPath+"/"+children.get(curIndex -1);
            beforePath.set(bnode);
        }
        return false;
    }

    public void lock() {
        if(! tryLock()) {
            // 阻塞等待鎖的釋放
            waitForLock();
            // 重新?lián)屾i
            lock();
        }
    }
    private void waitForLock() {

        CountDownLatch cdl = new CountDownLatch(1);
        // 用zkwatcher事件來(lái)通知
            IZkDataListener listener = new IZkDataListener() {

            public void handleDataDeleted(String dataPath) throws Exception {
                System.out.println("================zk節(jié)點(diǎn)被刪除================");
                cdl.countDown();
            }

            public void handleDataChange(String dataPath, Object data) throws Exception {
            }
        };
        // watcher /zk 數(shù)據(jù)變化
        client.subscribeDataChanges(beforePath.get(), listener);

        // 請(qǐng)求線程去進(jìn)行阻塞等待
        if(client.exists(beforePath.get())) {
            try {
                cdl.await();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        // 取消注冊(cè)事件
        client.unsubscribeDataChanges(beforePath.get(), listener);
    }

至此一個(gè)分布式鎖就實(shí)現(xiàn)了。

接下來(lái)說(shuō)Zookeeper的偽集群。搭建的時(shí)候需要注意的情況:
1、DataDir的位置。
2、Zookeeper的端口號(hào)
3、myid文件,myid文件是創(chuàng)建在DataDir目錄下的,myid文件就是給一個(gè)id數(shù),id數(shù)需與server.1 ... 后邊的編號(hào)一致。
然后分別啟動(dòng)三臺(tái)服務(wù)器,注意看服務(wù)器輸出的日志消息。不出意外的話Zookeeper的集群就可以搭建成功了!


分享名稱:分布式之Zookeeper一(分布式鎖與Zookeeper集群)
本文來(lái)源:http://weahome.cn/article/jjcjge.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部