検索
ホームページバックエンド開発PHPチュートリアルRedis での分散ロック実装の詳細な説明

Redis での分散ロック実装の詳細な説明

Dec 14, 2017 pm 02:42 PM
redis配布された成し遂げる

以前に使用したスケジュールされたタスクは 1 台のマシンにのみデプロイされていました。単一点の問題を解決し、タスクが 1 台のマシンでのみ実行されるようにするには、ロックの問題を考慮する必要があるため、時間をかけて調査しました。 。 この問題。分散ロックを実装するにはどうすればよいですか?この記事では、Redis で分散ロックを実装する方法の例を中心に紹介します。参考になれば幸いです。

ロックの本質は相互排他であり、クライアントがいつでも同じロックを保持できるようにするため、redis を使用して分散ロックを実装することを検討している場合、最も簡単な解決策は、インスタンスにキー値を作成し、そのロックを解放することです。ロック時間、キー値を削除します。ただし、信頼性の高い完全な分散ロックを実現するには、多くの詳細を考慮する必要があります。正しい分散ロックの作成方法を見てみましょう。

分散ロック SETNX の単一マシン バージョン

そこで、redis の setNX (SET if Not eXists) コマンドに基づいて単純なロックを直接実装します。疑似コードに直接アクセスします。

ロックの取得:

SET resource_name my_random_value NX PX 30000

ロックの解放:

 if redis.call("get",KEYS[1]) == ARGV[1] then
  return redis.call("del",KEYS[1])
 else
  return 0
 end

注意すべき詳細:

まず、ロックを取得するときにタイムアウトを設定する必要があります。タイムアウトは、ネットワークの問題が発生した後にクライアントがクラッシュしたり、ロックが保持されたりするのを防ぐために設定されます。システム全体がデッドロック状態になっています。

setNX コマンドを使用して、クエリと書き込みステップがアトミックであることを確認します

ロックが解放されると、KEYS[1]) == ARGV[1] と判断されます。ここで、KEYS[1] は redis から取得されます。 ARGV[1] は上で生成された my_random_value です。このような判断を行うのは、ロックされた保持者によるロックを確実に解除するためである。この検証ステップは実行されないと仮定します:

  1. クライアント A がロックを取得し、後続のスレッドがハングします。この時間はロックの有効期限を超えています。

  2. ロックの有効期限が切れると、クライアント B がロックを取得します。

  3. クライアント A が回復した後、関連イベントを処理した後、redis に対して del コマンドを発行します。ロックが解放されました

  4. クライアントCがロックを取得します。現時点では、システム内の 2 つのクライアントが同時にロックを保持します。

この問題の鍵は、クライアント B が保持しているロックがクライアント A によって解放されることです。

操作のアトミック性を確保するには、Lua スクリプトを使用してロックを解放する必要があります。ロックの解除には、get、判定、delの3つのステップが含まれます。 3 つのステップの原子性が保証できない場合、分散ロックには同時実行性の問題が発生します。

上記の詳細に注意を払うと、単一の Redis ノードの分散ロックが実現されます。

この分散ロックにはまだ単一の Redis ポイントが存在します。 Redis はマスター/スレーブ アーキテクチャを採用しているため、障害が発生した場合はスレーブに切り替えるだけだと思われるかもしれませんが、Redis のレプリケーションは非同期です。

  1. クライアント A がマスターのロックを取得した場合。

  2. マスターがスレーブにデータを同期する前に、マスターがダウンします。

  3. クライアント B がスレーブから再びロックを取得しました。

このように、マスターのダウンタイムにより、複数の人が同時にロックを保持することになります。システムが複数の人による短期間のロックの保持を受け入れることができる場合。この簡単な解決策で問題は解決します。

でも、この問題が解決すれば。 Redis は Redlock ソリューションを正式に提供しています。

RedLockの実装

Redisシングルポイントの問題を解決するため。 Redis の作者は RedLock のソリューションを提案しました。計画は非常に巧妙かつ簡潔です。 RedLock の中心的なアイデアは、冗長性のために複数の Redis マスターを同時に使用することであり、これらのノードは完全に独立しており、これらのノード間でデータを同期する必要はありません。

N 個の Redis ノードがあると仮定します。N は 2 より大きい奇数である必要があります。 RedLock 実装手順:

  1. 現在時刻を取得します

  2. 上記の方法を使用して、N ノードの Redis ロックを順番に取得します。

  3. ロックの取得数が(N/2+1)より大きく、取得時間がロックの有効時間(ロック有効時間)未満であれば、有効なロックが取得されたとみなします。ロックの自動解放時間は、最初のロック解放時間から、以前にロックを取得するのに費やした時間を引いた時間です。

  4. ロックの取得数が(N/2+1)未満の場合、またはロックの有効期限(ロック有効時間)内にロックの取得が不十分な場合は、ロックの取得に失敗したものとみなされます。このとき、ロック解除メッセージをすべてのノードに送信する必要があります。

ロックを解除する実装は非常に簡単です。以前にロックが正常に取得されたかどうかに関係なく、すべての Redis ノードで解放操作を開始します。

同時に、いくつかの詳細に注意する必要があります:

ロックを取得するための再試行の間隔は、固定時間ではなくランダムな範囲にする必要があります。これにより、複数のクライアントが同時にロック取得操作を Redis クラスターに送信することを防ぎ、同時競合を回避できます。同じ数のロックを同時に取得する状況。 (確率は非常に低いですが)

マスターノードに障害が発生した場合、回復時間の間隔はロックの有効時間よりも長くなければなりません。

  1. 3 つの Redis ノード A、B、C があるとします。

  2. クライアント foo は 2 つのロック A と B を取得します。

  3. このとき、Bはダウンし、メモリ内のデータはすべて失われます。

  4. ノード B が応答します。

  5. このとき、クライアントバーはロックを再取得し、2つのノードBとCを取得します。

  6. 現時点では、さらに 2 つのクライアントがロックを取得しています。

したがって、回復時間がロックの有効時間よりも長ければ、上記の状況は回避できます。同時に、パフォーマンス要件が高くない場合は、Redis の永続化オプションをオンにすることもできます。

まとめ

Redis の分散実装を理解した後、ほとんどの分散システムの原理は非常に単純ですが、分散システムの信頼性を確保するには、多くの詳細と些細な例外を支払う必要があると実際に感じました。に注意してください。

RedLock アルゴリズムによって実装された分散ロックはシンプルかつ効率的であり、そのアイデアは非常に賢明です。

しかし、RedLock は必ずしも安全なのでしょうか?この問題についても記事を書きます。ご期待ください。

関連する推奨事項:

分散ロックを実装する redisson の方法の原理の詳細な説明

php redis 分散ロックとタスク キューのコード例の詳細な説明

分散ロックの複数の実装方法

以上がRedis での分散ロック実装の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHP:サーバー側のスクリプト言語の紹介PHP:サーバー側のスクリプト言語の紹介Apr 16, 2025 am 12:18 AM

PHPは、動的なWeb開発およびサーバー側のアプリケーションに使用されるサーバー側のスクリプト言語です。 1.PHPは、編集を必要とせず、迅速な発展に適した解釈言語です。 2。PHPコードはHTMLに組み込まれているため、Webページの開発が簡単になりました。 3。PHPプロセスサーバー側のロジック、HTML出力を生成し、ユーザーの相互作用とデータ処理をサポートします。 4。PHPは、データベースと対話し、プロセスフォームの送信、サーバー側のタスクを実行できます。

PHPとWeb:その長期的な影響を調査しますPHPとWeb:その長期的な影響を調査しますApr 16, 2025 am 12:17 AM

PHPは過去数十年にわたってネットワークを形成しており、Web開発において重要な役割を果たし続けます。 1)PHPは1994年に発信され、MySQLとのシームレスな統合により、開発者にとって最初の選択肢となっています。 2)コア関数には、動的なコンテンツの生成とデータベースとの統合が含まれ、ウェブサイトをリアルタイムで更新し、パーソナライズされた方法で表示できるようにします。 3)PHPの幅広いアプリケーションとエコシステムは、長期的な影響を促進していますが、バージョンの更新とセキュリティの課題にも直面しています。 4)PHP7のリリースなど、近年のパフォーマンスの改善により、現代の言語と競合できるようになりました。 5)将来的には、PHPはコンテナ化やマイクロサービスなどの新しい課題に対処する必要がありますが、その柔軟性とアクティブなコミュニティにより適応性があります。

なぜPHPを使用するのですか?利点と利点が説明されましたなぜPHPを使用するのですか?利点と利点が説明されましたApr 16, 2025 am 12:16 AM

PHPの中心的な利点には、学習の容易さ、強力なWeb開発サポート、豊富なライブラリとフレームワーク、高性能とスケーラビリティ、クロスプラットフォームの互換性、費用対効果が含まれます。 1)初心者に適した学習と使用が簡単。 2)Webサーバーとの適切な統合および複数のデータベースをサポートします。 3)Laravelなどの強力なフレームワークを持っています。 4)最適化を通じて高性能を達成できます。 5)複数のオペレーティングシステムをサポートします。 6)開発コストを削減するためのオープンソース。

神話を暴く:PHPは本当に死んだ言語ですか?神話を暴く:PHPは本当に死んだ言語ですか?Apr 16, 2025 am 12:15 AM

PHPは死んでいません。 1)PHPコミュニティは、パフォーマンスとセキュリティの問題を積極的に解決し、PHP7.xはパフォーマンスを向上させます。 2)PHPは最新のWeb開発に適しており、大規模なWebサイトで広く使用されています。 3)PHPは学習しやすく、サーバーはうまく機能しますが、タイプシステムは静的言語ほど厳格ではありません。 4)PHPは、コンテンツ管理とeコマースの分野で依然として重要であり、エコシステムは進化し続けています。 5)OpcacheとAPCを介してパフォーマンスを最適化し、OOPと設計パターンを使用してコードの品質を向上させます。

PHP対Pythonの議論:どちらが良いですか?PHP対Pythonの議論:どちらが良いですか?Apr 16, 2025 am 12:03 AM

PHPとPythonには独自の利点と短所があり、選択はプロジェクトの要件に依存します。 1)PHPは、Web開発に適しており、学習しやすく、豊富なコミュニティリソースですが、構文は十分に近代的ではなく、パフォーマンスとセキュリティに注意を払う必要があります。 2)Pythonは、簡潔な構文と学習が簡単なデータサイエンスと機械学習に適していますが、実行速度とメモリ管理にはボトルネックがあります。

PHPの目的:動的なWebサイトの構築PHPの目的:動的なWebサイトの構築Apr 15, 2025 am 12:18 AM

PHPは動的なWebサイトを構築するために使用され、そのコア関数には次のものが含まれます。1。データベースに接続することにより、動的コンテンツを生成し、リアルタイムでWebページを生成します。 2。ユーザーのインタラクションを処理し、提出をフォームし、入力を確認し、操作に応答します。 3.セッションとユーザー認証を管理して、パーソナライズされたエクスペリエンスを提供します。 4.パフォーマンスを最適化し、ベストプラクティスに従って、ウェブサイトの効率とセキュリティを改善します。

PHP:データベースとサーバー側のロジックの処理PHP:データベースとサーバー側のロジックの処理Apr 15, 2025 am 12:15 AM

PHPはMySQLIおよびPDO拡張機能を使用して、データベース操作とサーバー側のロジック処理で対話し、セッション管理などの関数を介してサーバー側のロジックを処理します。 1)MySQLIまたはPDOを使用してデータベースに接続し、SQLクエリを実行します。 2)セッション管理およびその他の機能を通じて、HTTPリクエストとユーザーステータスを処理します。 3)トランザクションを使用して、データベース操作の原子性を確保します。 4)SQLインジェクションを防ぎ、例外処理とデバッグの閉鎖接続を使用します。 5)インデックスとキャッシュを通じてパフォーマンスを最適化し、読みやすいコードを書き、エラー処理を実行します。

PHPでのSQL注入をどのように防止しますか? (準備された声明、PDO)PHPでのSQL注入をどのように防止しますか? (準備された声明、PDO)Apr 15, 2025 am 12:15 AM

PHPで前処理ステートメントとPDOを使用すると、SQL注入攻撃を効果的に防ぐことができます。 1)PDOを使用してデータベースに接続し、エラーモードを設定します。 2)準備方法を使用して前処理ステートメントを作成し、プレースホルダーを使用してデータを渡し、メソッドを実行します。 3)結果のクエリを処理し、コードのセキュリティとパフォーマンスを確保します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール