序文一般的な作業でよく使用される分散ロックは、Redis と ZooKeeper に基づいています。上記ではRedissonロックに関連するソースコードを紹介しました。それでは、ZooKeeper に基づくロックを見てみましょう。それが Curator フレームワークです。 Curator ロックには多くの種類があります。この記事では、共有再入可能ロックを分析します。 記事が長すぎると読みにくくなることを考慮したので、記事を適切に分割しています。 1環境設定このマシンには3つのノードがあります バージョン: 3.7.0 システム: macOS インストール方法: brew install zookeeper Curator Maven 依存関係バージョン: 5.1.0
2 ロックの例詳細については公式ドキュメント[1]を参照してください。 ロックする前に ロックする前は、ZooKeeper にはノード/Zookeeper が 1 つだけあります。 ロック /locks/lock_01 パスにロックを追加します。 ロック後:
3 ソースコードをロックするPS: 以下のコード スクリーンショットのコード スタイルは、Curator ソース コードのコード スタイルです。 入り口 プロセス間ミューテックス#内部ロック まず、threadData から現在のスレッドを取得します。ここでは現在のスレッドは確実に存在しないため、attemptLock メソッドを入力します。 この方法には、後で紹介するロック再入のロジックも含まれます。 ロック ロック内部#ロックの試行 核となる部分は次の 2 行です。
一時的なシーケンスノードを作成する 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 の使い方と、ロック プロセス、ソース コード分析について主に紹介します。 内容の概要は次のとおりです。 注目すべき重要なポイントは次のとおりです。
参考リンク: [1]ZooKeeper共有再入可能ロック: https://curator.apache.org/curator-recipes/shared-reentrant-lock.html この記事はWeChatの公開アカウント「Programmer Xiaohang」から転載したもので、以下のQRコードからフォローできます。この記事を転載する場合は、プログラマーXiaohangの公式アカウントまでご連絡ください。 |
<<: 消費者実装ロジック - Kafka 知識システム (IV)
>>: Docker 以上の 8 つのオープンソース コンテナ管理ソリューション
「私は36Kr、Huxiu、Leifengをよく読んでいます。初期段階の投資家として、国内のテクノロ...
ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービス企業がインターネットマー...
ウェブサイトを成功させるには、多くの要素が必要です。運だけではありません。トレンドや実力も重要です。...
5月4日にKubernetesバージョン1.24が正式にリリースされました。以前のバージョンと同様に...
かつて、インターネットは新興産業として、急速な発展の初期段階で多くのトラフィック配当を生み出しました...
以前共有されたコンテンツは、ブランドキーワードの最適化、ナレッジ検索マーケティング、QQグループのプ...
[元記事は51CTO.comより] 12月25日、 QingCloud副社長の林元氏はメディアに対し...
概要: 先週金曜日に LastPass のネットワークがハッカーに侵入され、攻撃者はユーザー アカウ...
Jollyworkshosting は、2009 年に VPS 事業を開始したフィリピンのインターネ...
重複コンテンツは、ウェブマスターの間で常に話題の 1 つです。重複コンテンツに関して最もよく言われる...
12月20日、テンセントの2020 Techo Park開発者会議の「次世代統合ハードウェアおよびソ...
greencloudvps (グリーンクラウド、グリーンクラウドvps)の東京、日本vpsは購入しや...
大学の期末試験中にストレスを感じる若い学生疫病の影響で、最も長い連休と最も家にこもる春節が誕生し、1...
[[258943]]ハリー・シャム博士 マイクロソフトのエグゼクティブバイスプレジデント、マイクロソ...
何もすることがなかったので、テンセントの微博と新浪微博を開きました。どちらも今最もホットなソーシャル...