序文Redis に基づく Redisson 分散インターロック RedissonMultiLock オブジェクトは、複数の RLock オブジェクトをインターロックに関連付けることができ、各 RLock オブジェクト インスタンスは異なる Redisson インスタンスから取得できます。 もちろん公式サイトの紹介です。具体的には何ですか?連動するMultiLockの使い方とソースコードを見てみましょう! 1マルチロックの使用公式ドキュメントによると、ここでの Redisson クライアントは異なる場合があります。もちろん、一般的な仕事では、クライアントが必要ないとは言いません。 2 ロックMultiLock ロックについて読む前に、通常のロックに関する関連記事を読んでおく必要があります。 ソースコードエントリ: org.redisson.RedissonMultiLock#lock() デフォルトのタイムアウトのleaseTimeは設定されていないため、-1になります。 このメソッドは長すぎるので、分割して読んでみましょう。
waitTime = 4500、leaseTime = -1、unit = MILLISECONDS のパラメータを指定して tryLock メソッドを呼び出します。 tryLock のロジックを見てみましょう。 leasingTime != -1 が満たされていないため、この部分は直接スキップされます。 waitTime != -1 条件が満たされ、remainTime = 4500、lockWaitTime = 4500 になります。 したがって、failedLocksLimit() メソッドは直接 0 を返します。これは、すべてのロックが正常に取得される必要があることを意味します。 重要なポイントは次のとおりです。 すべてのロックを横断し、1 つずつロックします。 ロックのロジックは再入可能ロックと変わりません。したがって、Lua スクリプトは分析されません。 上記はtryLockがロックされた後の結果です。 ロックが正常に取得された場合、成功したロックは acquireLocks コレクションに格納されます。 ロックに失敗した場合はfailedLocksLimitを判断する必要があります。ここでは 0 なので、正常にロックされたセット acquireLocks 内のすべてのロックが直接解放され、正常にロックされたセットがクリアされてイテレータが復元されます。 各ロックの後に、残りのロック時間 remainTime が更新されます。 remainTime が 0 以下の場合、ロックがタイムアウトしたことを意味し、直接 false が返されます。 これにより、外部の while (true) ロジックが実行され、RedissonMultiLock#tryLock が再度実行されます。 3 ロック解除ロックのロジックを読んだ後では、ロックの解除が理解しやすくなります。 トラバースしてロックを直接解除するだけです。 lock.unlockAsync() は、呼び出される RedissonBaseLock#unlockAsync() メソッドです。 4 結論私の理解では、図は次のようになります。 一般的には、key1、key2、key3...keyN を List コレクションに入れて、すべてが成功するまで反復処理してロックします。ロックを解除するときは、ロックを再度通過してロックを解除します。 この記事はWeChatの公開アカウント「Programmer Xiaohang」から転載したもので、以下のQRコードからフォローできます。この記事を転載する場合は、プログラマーXiaohangの公式アカウントまでご連絡ください。 |
<<: F5: エッジ コンピューティングはデジタル バンキングのエクスペリエンスをどのように変えるのでしょうか?
>>: 分散システムアーキテクチャの1つであるマスターワーカーアーキテクチャ
誰もが自分のアプリに自信を持っていますが、そう感じていない人もいるかもしれません。しかし、アプリケー...
最近、A5で地元タレントサイトの運営に関する記事をたくさん見ましたが、これは地元タレントサイトが今い...
2017 年 5 月 10 日、大手仮想ホスティング会社およびソリューション プロバイダーである R...
香港の新しい VPS ブランドである Juhost は、主に香港で中国本土に直接接続された 100M...
Google Analtics と同様に、Google Urchin は e コマース機能を追跡し、...
急速な経済発展の時代において、人々は物事に可能性があるかどうか、またそれを始める、あるいは続ける必要...
O2O市場は現在、起業家と投資家がしのぎを削る重要な戦場の一つです。ますます多くのプラットフォームレ...
まず、2年前の検索エンジンマーケティングの人気を振り返ってみましょう。2年前、検索エンジンマーケティ...
ある起業家が自身のブランドの海外旗艦店をオープンしたが、小紅書や抖音などの主流プラットフォームではラ...
昨日、たまたまネットで記事を見ました。どのページだったかは覚えていませんが、長年 SEO に携わって...
網易科技ニュース、8月1日、網易科技は独占的に、Pangu SearchとJikesouが本日10時...
SEO の仕事は血と涙を伴う厳しい仕事だという人もいます。王世凡はこの意見に大いに賛同しており、中国...
多くの Java 開発者は Spring Framework を使用して Web サービスを迅速に作...
[51CTO.com からのオリジナル記事] 政府クラウドは、クラウド コンピューティング テクノロ...
クラウド コンピューティングは現在、急速な発展段階にあり、今こそクラウド コンピューティングのスキル...