getbookNameQUEUED>saddtag"Redis""NewBook"QUEUED>smemberstagQUEUED>e"/> getbookNameQUEUED>saddtag"Redis""NewBook"QUEUED>smemberstagQUEUED>e">
検索
ホームページデータベースRedisRedis トランザクション インスタンスの分析

    Redis での使用法

    Redis は、multi、exec、discard、watch を通じてトランザクション関数を実装します。

    • multi: トランザクションの開始

    • exec: トランザクションをコミットして実行

    • discard: トランザクションをキャンセル

    • watch: トランザクションの開始前に任意の数のキーを監視します

    > multi
    OK
    > set bookName "Redis"
    QUEUED
    > get bookName
    QUEUED
    > sadd tag "Redis" "New Book"
    QUEUED
    > smembers tag
    QUEUED
    > exec
    1) OK
    2) "Redis"
    3) (integer) 2
    4) 1) "Redis"
       2) "New Book"

    トランザクションの開始

    > multi
    OK

    このコマンドは、 Redis_multi オプション、クライアントを非トランザクション状態からトランザクション状態に変更させます

    Redis トランザクション インスタンスの分析

    Command enqueue

    > set bookName "Redis"
    QUEUED
    > get bookName
    QUEUED
    > sadd tag "Redis" "New Book"
    QUEUED
    > smembers tag
    QUEUED

    Redis コマンドはすぐには実行されませんが、まず、トランザクションがコミットされるまで、トランザクション キューから高度な First に入ります。 QUEUED は、このコマンドがトランザクション キューに入ったことを示します。

    トランザクションの実行

    > exec
    1) OK
    2) "Redis"
    3) (integer) 2
    4) 1) "Redis"
       2) "New Book"

    exec コマンドを実行すると、Redis はクライアントによって保存されたトランザクション キューに従って先入れ先出し方式でトランザクション キュー内のコマンドを実行します。キューに入れられる最初のコマンド 最初に実行され、キューに入れられた最後のコマンドが最後に実行されます。 exec コマンドの実行後、Redis は結果を応答キューに保存し、キューをクライアントに送信します。クライアントはトランザクション状態を終了し、トランザクションが完了します。

    discard コマンド

    > multi
    OK
    > set author "lisi"
    QUEUED
    > discard
    OK
    > get author
    (nil)

    discard は、トランザクションをキャンセルするコマンドで、トランザクションがキャンセルされたことを示します。クライアントがトランザクション状態を終了して非トランザクション状態に戻る場合は、Redis_multi オプションをオフにする必要があります。

    Redis トランザクション インスタンスの分析

    watch コマンド

    # Redis 客户端1
    > watch letter
    OK
    > multi
    OK
    > set letter a
    QUEUED
    > exec
    (nil)
    
    
    # Redis 客户端2
    > set letter b
    OK
    
    # Redis 客户端1
    > get letter
    "b"

    クライアント 1 がトランザクションに入ると、ウォッチは文字キーを設定し、その値を a に設定しますが、トランザクションはまだ開始されていません。提出する。クライアント 2 は、文字の値を b に設定します。クライアント 1 がトランザクションをコミットした後、返される結果は nil ですが、get コマンドを呼び出すと、letter の値が b として取得できます。これは、文字キーが別のクライアントによって変更されると、トランザクションはキャンセルされ、実行されず、失敗することを意味します。

    watch コマンドは、トランザクションが開始される前に任意の数のキーを監視します。トランザクションを実行するために Excel コマンドを呼び出すときに、監視されているキーのいずれかが他のクライアントによって変更されている場合、トランザクション全体は実行されなくなります。直接戻ります。失敗します。

    Redis トランザクション インスタンスの分析

    トランザクション例外

    コマンド エラー

    > set letter ac
    QUEUED
    > get letter ac
    (error) ERR wrong number of arguments for 'get' command
    > exec
    (error) EXECABORT Transaction discarded because of previous errors.

    トランザクション内のコマンド例外は構文エラーであり、トランザクションが失敗します。実行されました。

    実行時例外

    > multi
    OK
    > lpush books "Redis"
    QUEUED
    > incr books
    QUEUED
    > lpush books "Python"
    QUEUED
    > lrange books 0 -1
    QUEUED
    > exec
    1) (integer) 1
    2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
    3) (integer) 2
    4) 1) "Python"
       2) "Redis"

    上の例は、文字列に対して incr コマンドを実行できないため、トランザクションの実行中にエラーが発生したことを示しています。 、後続 コマンドは実行を継続するため、books の値は引き続き設定されます。この例外は、プログラマがコード内でのみ回避できます。

    トランザクションの ACID

    アトミック性

    アトミックとは、トランザクションが一緒に正常に実行されるか、一緒に失敗してロールバックされるかのいずれかを意味します。 Redis が提供するすべての API はアトミック操作です。この場合、Redis トランザクションは、一連の操作のアトミック性を保証するだけで済みます。ただし、実行時例外の場合、トランザクション内のコマンドで例外が発生した場合、他のコマンドは実行され続けます。ロールバック メカニズムはありません。したがって、Redis トランザクションがアトミックであることは保証されていません。

    一貫性

    トランザクション例外

    コマンドエラーが発生した場合、トランザクションは実行できません。実行時例外の場合、Redis は戻り結果にエラーを含めます。以降の実行には影響しないため、トランザクションは一貫しています。

    Redis プロセスが終了します

    ピュア メモリ モードでは、Redis は永続化を実行せず、再起動後はデータベースが空になるため、トランザクションの一貫性が保たれます。

    RDBモードでは、トランザクションは途中でRDBファイルを保存する作業を行わず、トランザクションが完了して初めてRDB作業が開始される場合があります。そのため、トランザクション実行中にRedisのプロセスが強制終了され、どんなに成功してもRDBファイルには保存されないので一貫性が保たれます。

    AOF モードでは、トランザクション ステートメントの一部が AOF ファイルに書き込まれ、正常に保存されます。不完全なトランザクションは AOF ファイルに保存されます。Redis を再起動するときに、AOF ファイルが不完全であることを確認し、Redis が終了します。エラー。この不完全なトランザクションは、再起動が成功する前に削除する必要があるため、一貫性が保たれます。

    AOF モードでは、トランザクションは AOF ファイルに書き込まれないため、Redis データベースの再起動後、最新のデータが AOF ファイルに正常に保存されます。このトランザクションにはデータがないため、一貫性があります。

    分離

    Redis は単一プロセス プログラムであり、トランザクションの実行時にトランザクションが中断されないことが保証されており、トランザクション キュー内のすべてのコマンドが実行されるまでトランザクションを実行できます。したがって、トランザクションは分離されます。

    永続性

    ピュア メモリ モードでは、トランザクションは明らかに永続的ではありません。

    RDB モードでは、トランザクション実行後 RDB ファイルが更新されるまでの間にサーバーがダウンする可能性があるため、RDB モードのトランザクションは永続的ではありません。

    AOF モードでは、コマンドを AOF ファイルに追加しますが、ファイルの書き込みはすぐにディスクに書き込まれず、最初にバッファーに保存されます。したがって、データがディスクに保存される間隔は非常に短くなります。このモードのトランザクションも耐久性がありません。

    以上がRedis トランザクション インスタンスの分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明
    この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
    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は、高性能および低遅延のアプリケーションでうまく機能します。

    Redisの役割:データストレージと管理機能の調査Redisの役割:データストレージと管理機能の調査Apr 22, 2025 am 12:10 AM

    Redisは、データストレージと管理において重要な役割を果たしており、複数のデータ構造と持続性メカニズムを通じて最新のアプリケーションの中核となっています。 1)Redisは、文字列、リスト、コレクション、注文されたコレクション、ハッシュテーブルなどのデータ構造をサポートし、キャッシュや複雑なビジネスロジックに適しています。 2)RDBとAOFの2つの持続方法を通じて、Redisは信頼できるストレージとデータの迅速な回復を保証します。

    Redis:NOSQLの概念の理解Redis:NOSQLの概念の理解Apr 21, 2025 am 12:04 AM

    Redisは、大規模なデータの効率的なストレージとアクセスに適したNOSQLデータベースです。 1.Redisは、複数のデータ構造をサポートするオープンソースメモリデータ構造ストレージシステムです。 2.キャッシュ、セッション管理などに適した、非常に速い読み取り速度と書き込み速度を提供します。 4.使用例には、基本的なキー値ペア操作と高度なコレクション重複排除関数が含まれます。 5.一般的なエラーには、接続の問題、データ型の不一致、メモリオーバーフローが含まれるため、デバッグに注意する必要があります。 6.パフォーマンス最適化の提案には、適切なデータ構造の選択とメモリ排除戦略の設定が含まれます。

    Redis:実際のユースケースと例Redis:実際のユースケースと例Apr 20, 2025 am 12:06 AM

    現実世界でのRedisのアプリケーションには、1。キャッシュシステムとして、データベースクエリを加速し、2。Webアプリケーションのセッションデータを保存するには、3。リアルタイムランキングを実装する4。メッセージ配信をメッセージキューとして簡素化する。 Redisの汎用性と高性能により、これらのシナリオで輝きます。

    Redis:その機能と機能の調査Redis:その機能と機能の調査Apr 19, 2025 am 12:04 AM

    Redisは、高速、汎用性、豊富なデータ構造のために際立っています。 1)Redisは、文字列、リスト、コレクション、ハッシュなどのデータ構造をサポートし、コレクションを注文します。 2)メモリを介してデータを保存し、RDBとAOFの持続性をサポートします。 3)Redis 6.0から始めて、マルチスレッドI/O操作が導入されました。これにより、高い並行性シナリオでパフォーマンスが向上しました。

    RedisはSQLまたはNOSQLデータベースですか?答えが説明しましたRedisはSQLまたはNOSQLデータベースですか?答えが説明しましたApr 18, 2025 am 12:11 AM

    redisisclassifiedsaNosqldatabasebasesakey-valuedataModelinsteaded ofthetraditionaldatabasemodel.itoffersspeedand andffficability、makingidealforreal-timeaplications andcaching、butmaynotbesbesutable fors cenariois requiring datientiantientioniity

    Redis:アプリケーションのパフォーマンスとスケーラビリティの向上Redis:アプリケーションのパフォーマンスとスケーラビリティの向上Apr 17, 2025 am 12:16 AM

    Redisは、データをキャッシュし、分散ロックとデータの持続性を実装することにより、アプリケーションのパフォーマンスとスケーラビリティを向上させます。 1)キャッシュデータ:Redisを使用して頻繁にアクセスしたデータをキャッシュして、データアクセス速度を向上させます。 2)分散ロック:Redisを使用して分散ロックを実装して、分散環境での操作のセキュリティを確保します。 3)データの持続性:データの損失を防ぐために、RDBおよびAOFメカニズムを介してデータセキュリティを確保します。

    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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

    ホットツール

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    WebStorm Mac版

    WebStorm Mac版

    便利なJavaScript開発ツール

    ZendStudio 13.5.1 Mac

    ZendStudio 13.5.1 Mac

    強力な PHP 統合開発環境

    SecLists

    SecLists

    SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

    SublimeText3 Mac版

    SublimeText3 Mac版

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