ZooKeeper 分散ロック キュレーター ソース コード 1: 再入可能ロック

ZooKeeper 分散ロック キュレーター ソース コード 1: 再入可能ロック

序文

一般的な作業でよく使用される分散ロックは、Redis と ZooKeeper に基づいています。上記ではRedissonロックに関連するソースコードを紹介しました。それでは、ZooKeeper に基づくロックを見てみましょう。それが Curator フレームワークです。

Curator ロックには多くの種類があります。この記事では、共有再入可能ロックを分析します。

記事が長すぎると読みにくくなることを考慮したので、記事を適切に分割しています。

1環境設定

このマシンには3つのノードがあります

バージョン: 3.7.0 システム: macOS インストール方法: brew install zookeeper Curator Maven 依存関係バージョン: 5.1.0

  1. <依存関係>
  2. <グループ ID>org.apache.curator</グループ ID>
  3. <artifactId>キュレーターレシピ</artifactId>
  4. <バージョン>5.1.0</バージョン>
  5. </依存関係>

2 ロックの例

詳細については公式ドキュメント[1]を参照してください。

ロックする前に

ロックする前は、ZooKeeper にはノード/Zookeeper が 1 つだけあります。

ロック

/locks/lock_01 パスにロックを追加します。

ロック後:

  • 永続ノード /locks/lock_01 が作成され、その下に子ノード _c_cc4fc045-5a1e-4378-b3c7-8a8d3fb9a37c-lock-0000000000 が存在します。
  • ノード /locks/lock_01/_c_cc4fc045-5a1e-4378-b3c7-8a8d3fb9a37c-lock-0000000000 は一時ノードです
  • ノード/locks/lock_01/_c_cc4fc045-5a1e-4378-b3c7-8a8d3fb9a37c-lock-0000000000のデータはマシンのIPアドレスです

3 ソースコードをロックする

PS: 以下のコード スクリーンショットのコード スタイルは、Curator ソース コードのコード スタイルです。

入り口

プロセス間ミューテックス#内部ロック

まず、threadData から現在のスレッドを取得します。ここでは現在のスレッドは確実に存在しないため、attemptLock メソッドを入力します。

この方法には、後で紹介するロック再入のロジックも含まれます。

ロック

ロック内部#ロックの試行

核となる部分は次の 2 行です。

  • 一時的なシーケンスノードを作成する
  • internalLockLoopは作成が成功したかどうかを決定します

一時的なシーケンスノードを作成する

StandardLockInternalsDriver#createsTheLock

ノードのモードが CreateMode.EPHEMERAL_SEQUENTIAL であることがわかります。これは、これが一時的なシーケンシャル ノードであることを意味します。

CreateBuilderImpl#forPath(java.lang.String, byte[]) を入力します。

client.getDefaultData() はローカル IP アドレスです。

adjustPath メソッドは、その名前が示すように、パスを調整するために使用されます。 UUID が生成され、/locks/lock_01 に連結されて、/locks/lock_01/_c_UUID-lock- になります。

一時的なシーケンシャルノードが作成されるため、末尾にシーケンスが自動的に追加され、最終的に /locks/lock_01/_c_UUID-lock-0000000000 になります。

ノードの具体的な作成は CreateBuilderImpl#pathInForeground にあります。

一時ノードを作成します。パスが存在する場合は、正常に作成されます。パスが存在しない場合は作成に失敗します。

作成に失敗した場合は、まずパスを作成し、次にノードを作成します。

4 結論

この記事では、ZooKeeper をベースにした分散ロック フレームワークである Curator の使い方と、ロック プロセス、ソース コード分析について主に紹介します。

内容の概要は次のとおりです。

注目すべき重要なポイントは次のとおりです。

  • ZooKeeper ベースの分散ロックは一時的なシーケンシャル ノードを使用し、親ノードは永続ノードです。
  • 一時ノードを作成するときに、親ノードが存在しない場合は、まず親ノード (パス) が作成されます。
  • ロック構造はロック /locks/lock_01 で、実際のロックは /locks/lock_01/_c_UUID-ロック-シリアル番号です。たとえば、/locks/lock_01/_c_cc4fc045-5a1e-4378-b3c7-8a8d3fb9a37c-lock-0000000000

参考リンク:

[1]ZooKeeper共有再入可能ロック: https://curator.apache.org/curator-recipes/shared-reentrant-lock.html

この記事はWeChatの公開アカウント「Programmer Xiaohang」から転載したもので、以下のQRコードからフォローできます。この記事を転載する場合は、プログラマーXiaohangの公式アカウントまでご連絡ください。

<<:  消費者実装ロジック - Kafka 知識システム (IV)

>>:  Docker 以上の 8 つのオープンソース コンテナ管理ソリューション

推薦する

IDC:中国の産業用クラウド市場規模は2020年後半に23億ドルに達する見込み

インターナショナル・データ・コーポレーション(IDC)が発表した最新の「中国産業クラウド市場追跡(2...

タオバオはO2Oに力を入れている:タオディアンディアンがテイクアウトサービスを開始

新浪科技は11月6日午前、アリババの「淘店店」事業部門が北京、上海、広州など19都市で携帯電話による...

必須のクラウド インフラストラクチャ自動化ツール 7 つ

現代のワークロードと厳しい配信スケジュールにより、組織は IT 運用とアプリケーション配信の効率化に...

ソーシャル メディア マーケティングの「4C」とはどういう意味ですか?

私たちの従来のマーケティングは、製品、価格、プロモーション チャネル、プロモーションの 4P に重点...

WeChat 7.0.7 内部ベータ版がリリース、ミニプログラムの評価が正式に「登場」?

WeChat 7.0.7 がリリースされました!昨日、WeChat は Android バージョン ...

IDC:中国の金融クラウド市場規模は2020年上半期に19億1000万米ドルに達した

11月17日、国際データコーポレーション(IDC)は最近、「中国金融クラウド市場(2020年上半期)...

消費者の意思決定に直接影響を与える 12 の社会心理学理論! (優れた)

毎日、私たち一人一人はさまざまな選択、判断、決断を行っています。たとえば、昼食に何を食べるか、服を買...

オリジナル: 外部リンクよりも量を優先すべきか、それとも質を優先すべきか?

多くのウェブマスターは、外部リンクが多ければランキングも上がると考えていますが、実際には外部リンクが...

SEO作業: 更新のために更新するSEO担当者は全員愚か者

サイトの更新は、すべての SEO 担当者の日常業務の 1 つです。この仕事は退屈なので、ほとんどの ...

人気のドメインは1元から、AIギフトは40%オフ、百度スマートクラウドはダブル11に6つの主要なギフトを発売

スピードを上げるためにまだチームを結成中ですか?まだあなたを切り刻んでくれる人を探していますか?こう...

企業によるマルチクラウドコンピューティングの導入を促進する要因

ビジネスが成長するにつれて、企業のクラウド コンピューティングに対するニーズも高まります。マルチクラ...

HTTPはRSA公開鍵暗号化アルゴリズムを使用してプレーンテキストを暗号化します

ウェブサイトが送信データを暗号化して盗難を防止したい場合、最も信頼性の高い方法は公開鍵暗号化アルゴリ...

「A Bite of China」ネットワークの成功要因の分析

「A Bite of China」 - 親戚や友人からこの言葉を発見したわけではありませんが、QQス...