検索
ホームページデータベースRedisRedisが実装する分散トランザクションの同時実行制御について詳しく解説

インターネット アプリケーションの発展に伴い、分散システムは避けられない傾向になりました。分散システムでは、複数のサービス間でデータのやり取りが必要であり、これらのデータのやり取りは一連のトランザクションとみなすことができます。複数のサービスがトランザクション上で同時に動作する場合、同時実行制御が必要です。

Redis は、分散システムで広く使用されている高性能のキー/値データベースです。トランザクションや監視など、さまざまなデータ構造とコマンドをサポートしているため、分散システムでの同時実行制御に最適です。この記事では、Redis が分散トランザクションの同時実行制御を実装する方法を詳しく紹介します。

1. Redis トランザクション

Redis トランザクションはアトミックな操作シーケンスです。これらの操作は 1 つのコマンドにパッケージ化し、別のステップで実行するために Redis サーバーに渡すことができるため、トランザクションのアトミック性が保証されます。 Redis トランザクションでは、MULTI コマンドを使用してトランザクションを開始し、EXEC コマンドを使用してトランザクションを送信し、DISCARD コマンドを使用してトランザクションをキャンセルできます。

Redis トランザクション内のコマンドは、トランザクションの開始後、コマンドごとにリクエストを送信せずに継続的に実行できます。クライアントはすべてのコマンドを実行した後、EXEC コマンドを使用してコマンドをバッチで Redis サーバーに送信できます。トランザクションの実行中にエラーが発生した場合、Redis はトランザクションをキャンセルし、すべての変更を禁止します。これにより、トランザクション内のすべての操作が実行されるか、何も実行されないかが保証されます。

2. Redis の監視

Redis の監視は、Redis が分散トランザクションを実装するための鍵です。 WATCH コマンドを使用して、データベース内の 1 つ以上のキーを監視します。 LIST、SET、ZSET、HASH、STRING などのデータ型では、監視対象のキーが存在する必要があります。監視中にこれらのキーが変更されると、トランザクションは正常にコミットされません。監視中に、クライアントは MULTI コマンドを使用して別のトランザクションを開始できます。

たとえば、次のコードは Redis 監視を使用します:

WATCH balance
balance = GET balance
balance = balance - 10
MULTI
SET balance $balance
EXEC

このコードは、「balance」という名前のキーを監視し、GET コマンドを使用してこのキーからデータを取得し、データを転送します。 10を引きます。次に、MULTI コマンドを使用してトランザクションを開始し、データを「残高」に書き戻します。

このトランザクションの他のクライアントも「balance」キーを監視し、クライアントが MULTI コマンドを実行する前にこのキーを変更すると、トランザクションは失敗します。トランザクションが正常に送信された場合、トランザクションに含まれるすべての操作が Redis サーバーで実行されるまで、他のクライアントは監視対象のキーを変更できません。

3. Redis 分散ロック

複数のクライアントで同時に Redis 監視コマンドを呼び出すことによって引き起こされる競合やデッドロックの問題を回避するために、分散ロックを使用できます。 Redis は、スタンドアロン ロックとクラスター ロックという 2 種類の分散ロックを提供します。

1. 単一マシン ロック

単一マシン ロックは、最も単純な分散ロックの実装です。スタンドアロン ロックでは、SETNX コマンドを使用してロック用のキー値を設定できます。たとえば、次のコードはスタンドアロン ロックを使用します:

SETNX lock_key $current_time

このコードは値を「lock_key」に設定します。このキーが以前に存在しなかった場合、設定は成功し、1 が返されます。それ以外の場合は、ロックが失敗したことを示す 0 が返されます。ロック期間中、他のクライアントはこのキーを変更できませんが、この時点では、クライアントは独自の操作を実行できます。クライアントは操作を完了したら、DEL コマンドを使用してロックを解放する必要があります。これにより、「lock_key」が削除され、ロックが解除されます。

2. クラスター ロック

クラスター ロックは、より強力な分散ロックの実装です。クラスター ロックでは、マルチノード ロックに Redlock アルゴリズムを使用できます。 Redlock アルゴリズムは、クロック同期に基づく分散ロック アルゴリズムです。 Redlock アルゴリズムでは、クライアントは最初にロックを取得し、現在の時刻をロックの有効期限として使用します。また、クライアントは他の Redis サーバーからロックを取得して、このロックが複数のノード間で一貫していることを確認する必要があります。ロック期間中、クライアントは独自の操作を実行できます。クライアントが操作を完了したら、ロックを解放する必要があります。これにより、ロックが削除され、すべての Redis サーバーのロックも同時に削除されます。

4. 概要

インターネット アプリケーション開発では、分散トランザクションと同時実行制御が非常に重要です。 Redis はトランザクション、監視、分散ロックなどのメカニズムを提供するため、分散システムでの同時実行制御に適しています。これらのメカニズムに精通していれば、開発者が分散システムをより適切に設計および開発し、分散トランザクションと同時実行制御の問題を解決できるようになります。

以上がRedisが実装する分散トランザクションの同時実行制御について詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Redis:そのコア機能と利点の調査Redis:そのコア機能と利点の調査Apr 30, 2025 am 12:22 AM

Redisのコア関数には、メモリストレージと持続性メカニズムが含まれます。 1)メモリストレージは、高性能アプリケーションに適した非常に高速な読み取り速度と書き込み速度を提供します。 2)永続性は、RDBとAOFによってデータが失われないことを保証し、選択はアプリケーションのニーズに基づいています。

Redisのサーバー側操作:提供するものRedisのサーバー側操作:提供するものApr 29, 2025 am 12:21 AM

redis'sserver-sideoperations offferidions and forexuctingcomplexoperationsontheserver.1)機能を調整することで、javascript、orredis'sscriptinglanguage、infulancingscalabilityandmantenmention

Redis:データベースまたはサーバー?役割を分かりやすいRedis:データベースまたはサーバー?役割を分かりやすいApr 28, 2025 am 12:06 AM

redisisbothadatabaseandaserver.1)asadatabase、itusesin memorystorage forfastaccess、理想的なforreal-timeapplicationsandcaching.2)asaserver、itupportspub/submessagingandaging andluascriptingforreal-communicationandserver-sideoperation。

Redis:NOSQLアプローチの利点Redis:NOSQLアプローチの利点Apr 27, 2025 am 12:09 AM

Redisは、高性能と柔軟性を提供するNOSQLデータベースです。 1)大規模データと高い並行性の処理に適したキー価値ペアを介してデータを保存します。 2)メモリストレージとシングルスレッドモデルは、速い読み取りと書き込みと原子性を確保します。 3)RDBおよびAOFメカニズムを使用してデータを持続し、高可用性とスケールアウトをサポートします。

Redis:そのアーキテクチャと目的を理解するRedis:そのアーキテクチャと目的を理解するApr 26, 2025 am 12:11 AM

Redisは、主にデータベース、キャッシュ、メッセージブローカーとして使用されるメモリデータ構造ストレージシステムです。そのコア機能には、シングルスレッドモデル、I/O多重化、持続メカニズム、複製、クラスタリング機能が含まれます。 Redisは、キャッシュ、セッションストレージ、メッセージキューのための実際のアプリケーションで一般的に使用されます。適切なデータ構造を選択し、パイプラインとトランザクションを使用し、監視とチューニングを使用することにより、パフォーマンスを大幅に改善できます。

Redis vs. SQLデータベース:重要な違​​いRedis vs. SQLデータベース:重要な違​​いApr 25, 2025 am 12:02 AM

RedisデータベースとSQLデータベースの主な違いは、Redisが高性能および柔軟性要件に適したインメモリデータベースであることです。 SQLデータベースは、複雑なクエリとデータの一貫性要件に適したリレーショナルデータベースです。具体的には、1)Redisは高速データアクセスとキャッシュサービスを提供し、キャッシュおよびリアルタイムのデータ処理に適した複数のデータ型をサポートします。 2)SQLデータベースは、テーブル構造を介してデータを管理し、複雑なクエリとトランザクション処理をサポートし、データの一貫性を必要とするeコマースや金融システムなどのシナリオに適しています。

Redis:データストアとサービスとしてどのように機能するかRedis:データストアとサービスとしてどのように機能するかApr 24, 2025 am 12:08 AM

redisactsassassadatastoreandaservice.1)asadatastore、itusesin memorystorage for fastorations、supporting variousdatastructureSlike-key-valuepairsandsortedsets.2)asaservice、iteasruascruascriptingrupting criptingforceptingpurplecomplecomplecprexoperations

Redis vs.その他のデータベース:比較分析Redis vs.その他のデータベース:比較分析Apr 23, 2025 am 12:16 AM

他のデータベースと比較して、Redisには次の独自の利点があります。1)非常に速い速度、および読み取り操作は通常、マイクロ秒レベルにあります。 2)豊富なデータ構造と操作をサポートします。 3)キャッシュ、カウンター、公開サブスクリプションなどの柔軟な使用シナリオ。 Redisまたはその他のデータベースを選択する場合、特定のニーズとシナリオに依存します。 Redisは、高性能および低遅延のアプリケーションでうまく機能します。

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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

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

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

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

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。