ホームページ データベース Redis Redisトランザクションとは何ですか

Redisトランザクションとは何ですか

Jun 28, 2020 pm 02:31 PM
redis

Redis トランザクションは、一度に複数のコマンドを実行できます。本質的にはコマンドのセットです。トランザクション内のすべてのコマンドはシリアル化され、挿入されることなく順番にシリアルに実行されます。その他のコマンド。

Redisトランザクションとは何ですか

1. Redis トランザクションとは何ですか?

複数のコマンドを一度に実行できます。これは基本的にコマンドの集合です。トランザクション内のすべてのコマンドはシリアル化され、他のコマンドに挿入されることなく順番にシリアルに実行されます

2. Redis トランザクションでは何ができるでしょうか?

キューでは、一連のコマンドが特定の連続的かつ排他的な方法で実行されます。

3. redis コマンドの使用方法は?

1. トランザクション関連コマンド:

(1) DISCARD: トランザクションをキャンセルし、トランザクション ブロック内のすべてのコマンドの実行を放棄します

(2) EXEC : トランザクションブロック内のコマンドを実行します

## (3) MULTI: トランザクションの開始をマークします

## (4) UNWATCH: WATCH コマンドによるすべてのキーの監視を解除します

# # (5​​) WATCH キー [key...]: 1 つ (または複数) のキーを監視します。トランザクションを実行する前に、この (またはこれらの) キーが他のコマンドによって変更されると、トランザクションは中断されます。

2. トランザクションエラーレポートの問題:

(1) ステートメントエラー: キュー追加時にエラーが直接レポートされ、このエラーが発生するとトランザクション全体がロールバックされます

(2) ロジック エラー: たとえば、文字列 1 が指定された場合、実行中にエラーが報告されます。この種のエラーは、トランザクション内の他の操作には影響しません。この記事のみがエラーを報告します。

3. 監視監視:

(1) 楽観的ロック:

楽観的ロック (楽観的) Lock), 楽観的なロックです。データを取得しに行くたびに、他の人がデータを変更しないと考えてロックしません。ただし、更新するときに、この間に他の人がデータを更新したかどうかを判断します。 「バージョン番号」などのメカニズムは、マルチ読み取りアプリケーション タイプで楽観的に使用され、スループットを向上させることができます。

楽観的ロック戦略: 送信されたバージョンは、更新される前に、現在記録されているバージョンよりも大きくなければなりません

## (2) 悲観的ロック

§

## )更新される前に現在のレコードのバージョンに拘束される 悲観的ロックでは、データを取得しに行くたびに、他の人が変更に従って動作するだろうと考えてしまい、上書きなどの問題が発生します。したがって、データを取得するたびにデータはロックされるため、他の人がデータを取得したい場合はブロックされます。変更が完了すると、ロックのロックを解除して使用できます。従来のリレーショナル データベースでは、このようなロック メカニズムが多数使用されています。 . 行ロック、テーブル ロック、読み取りロック、書き込みロックなど、これらはすべて操作を実行する前にテーブルをロックします。

ペシミスティック ロックはデータのセキュリティを確保しますが、パフォーマンスを低下させます

4 つおよび 3 つの機能

1. 個別の分離操作:

トランザクション内のすべてのコマンドはシリアル化され、順番に実行されます。トランザクションの実行中、他のクライアントから送信されたコマンド要求によって中断されることはありません。

2. 分離レベルの概念はありません:

トランザクションが送信される前に命令が実際に実行されることはないため、キュー内のコマンドは送信される前に実際には実行されません。 「トランザクション内のクエリは物理的な更新を認識する必要があるが、トランザクション外のクエリはこの問題を認識できない」という問題があります。

3. アトミック性は保証されていません:

Redis の場合同じトランザクション内 1 つのコマンドの実行が失敗しても、後続のコマンドはロールバックせずに実行されます。

(キューに参加するときにエラーが発生した場合、つまり Java に似たコンパイル時例外と実行時例外が発生した場合を除きます。コンパイルではロールバックが発生し、実行時例外はロールバックしません)

推奨チュートリアル : 「

Redis チュートリアル

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

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Redisクラスターモードの構築方法 Redisクラスターモードの構築方法 Apr 10, 2025 pm 10:15 PM

Redisクラスターモードは、シャードを介してRedisインスタンスを複数のサーバーに展開し、スケーラビリティと可用性を向上させます。構造の手順は次のとおりです。異なるポートで奇妙なRedisインスタンスを作成します。 3つのセンチネルインスタンスを作成し、Redisインスタンスを監視し、フェールオーバーを監視します。 Sentinel構成ファイルを構成し、Redisインスタンス情報とフェールオーバー設定の監視を追加します。 Redisインスタンス構成ファイルを構成し、クラスターモードを有効にし、クラスター情報ファイルパスを指定します。各Redisインスタンスの情報を含むnodes.confファイルを作成します。クラスターを起動し、CREATEコマンドを実行してクラスターを作成し、レプリカの数を指定します。クラスターにログインしてクラスター情報コマンドを実行して、クラスターステータスを確認します。作る

Redisデータをクリアする方法 Redisデータをクリアする方法 Apr 10, 2025 pm 10:06 PM

Redisデータをクリアする方法:Flushallコマンドを使用して、すべての重要な値をクリアします。 FlushDBコマンドを使用して、現在選択されているデータベースのキー値をクリアします。 [選択]を使用してデータベースを切り替え、FlushDBを使用して複数のデータベースをクリアします。 DELコマンドを使用して、特定のキーを削除します。 Redis-CLIツールを使用してデータをクリアします。

Redisキューの読み方 Redisキューの読み方 Apr 10, 2025 pm 10:12 PM

Redisのキューを読むには、キュー名を取得し、LPOPコマンドを使用して要素を読み、空のキューを処理する必要があります。特定の手順は次のとおりです。キュー名を取得します:「キュー:キュー」などの「キュー:」のプレフィックスで名前を付けます。 LPOPコマンドを使用します。キューのヘッドから要素を排出し、LPOP Queue:My-Queueなどの値を返します。空のキューの処理:キューが空の場合、LPOPはnilを返し、要素を読む前にキューが存在するかどうかを確認できます。

Redisコマンドの使用方法 Redisコマンドの使用方法 Apr 10, 2025 pm 08:45 PM

Redis指令を使用するには、次の手順が必要です。Redisクライアントを開きます。コマンド(動詞キー値)を入力します。必要なパラメーターを提供します(指示ごとに異なります)。 Enterを押してコマンドを実行します。 Redisは、操作の結果を示す応答を返します(通常はOKまたは-ERR)。

Redisロックの使用方法 Redisロックの使用方法 Apr 10, 2025 pm 08:39 PM

Redisを使用して操作をロックするには、setnxコマンドを介してロックを取得し、有効期限を設定するために有効期限コマンドを使用する必要があります。特定の手順は次のとおりです。(1)SETNXコマンドを使用して、キー価値ペアを設定しようとします。 (2)expireコマンドを使用して、ロックの有効期限を設定します。 (3)Delコマンドを使用して、ロックが不要になったときにロックを削除します。

Centos RedisでLUAスクリプト実行時間を構成する方法 Centos RedisでLUAスクリプト実行時間を構成する方法 Apr 14, 2025 pm 02:12 PM

Centosシステムでは、Redis構成ファイルを変更するか、Redisコマンドを使用して悪意のあるスクリプトがあまりにも多くのリソースを消費しないようにすることにより、LUAスクリプトの実行時間を制限できます。方法1:Redis構成ファイルを変更し、Redis構成ファイルを見つけます:Redis構成ファイルは通常/etc/redis/redis.confにあります。構成ファイルの編集:テキストエディター(VIやNANOなど)を使用して構成ファイルを開きます:sudovi/etc/redis/redis.conf luaスクリプト実行時間制限を設定します。

Redisコマンドラインの使用方法 Redisコマンドラインの使用方法 Apr 10, 2025 pm 10:18 PM

Redisコマンドラインツール(Redis-Cli)を使用して、次の手順を使用してRedisを管理および操作します。サーバーに接続し、アドレスとポートを指定します。コマンド名とパラメーターを使用して、コマンドをサーバーに送信します。ヘルプコマンドを使用して、特定のコマンドのヘルプ情報を表示します。 QUITコマンドを使用して、コマンドラインツールを終了します。

Debian Readdirのパフォーマンスを最適化する方法 Debian Readdirのパフォーマンスを最適化する方法 Apr 13, 2025 am 08:48 AM

Debian Systemsでは、Directoryコンテンツを読み取るためにReadDirシステム呼び出しが使用されます。パフォーマンスが良くない場合は、次の最適化戦略を試してください。ディレクトリファイルの数を簡素化します。大きなディレクトリをできる限り複数の小さなディレクトリに分割し、Readdirコールごとに処理されたアイテムの数を減らします。ディレクトリコンテンツのキャッシュを有効にする:キャッシュメカニズムを構築し、定期的にキャッシュを更新するか、ディレクトリコンテンツが変更されたときに、頻繁な呼び出しをreaddirに削減します。メモリキャッシュ(memcachedやredisなど)またはローカルキャッシュ(ファイルやデータベースなど)を考慮することができます。効率的なデータ構造を採用する:ディレクトリトラバーサルを自分で実装する場合、より効率的なデータ構造(線形検索の代わりにハッシュテーブルなど)を選択してディレクトリ情報を保存およびアクセスする

See all articles