検索
ホームページデータベースRedisRedis の遅延二重削除戦略の使用方法

通常は、データベースアクセスの負担を軽減するために、Redisキャッシュの使用を優先します。ただし、多数のユーザーがシステムにアクセスすると、まずキャッシュにクエリが実行され、キャッシュにデータがない場合はデータベースにクエリが実行され、その後、データがキャッシュに更新されます。 、データベース内のデータが変更された場合は、redis に同期する必要があります。同期プロセス中、MySQL と redis の間のデータの一貫性を確保する必要があります。この同期プロセス中に短いデータ遅延が発生するのは通常のことです。ただし、最終的には、mysql とキャッシュの間の一貫性を確保する必要があります。

//我们通常使用redis的逻辑
    //通常我们是先查询reids
    String value = RedisUtils.get(key);
    if (!StringUtils.isEmpty(value)){
        return value;
    }
//从数据库中获取数据
    value = getValueForDb(key);
    if (!StringUtils.isEmpty(value)){
           RedisUtils.set(key,value);
        return value;
     }

1. 遅延二重削除とは何ですか?

遅延二重削除戦略は、分散システムで一貫性を維持するためのデータベース ストレージとキャッシュ データの一般的な戦略ですが、強力な一貫性はありません。実際、どのソリューションを使用しても、Redis のダーティ データの問題は回避できません。この問題を軽減することしかできません。この問題を完全に解決するには、同期ロックと対応するビジネス ロジック レベルを使用して解決する必要があります。

2. 遅延二重削除を実行する必要があるのはなぜですか?

通常、データベース データを更新するときは、redis にキャッシュされたデータを同期する必要があるため、通常 2 つの解決策があります:

  • 最初の解決策: 最初の更新操作を実行します。を選択し、キャッシュクリアを実行します。

  • 2 番目のオプション: 最初にキャッシュのクリアを実行してから、更新操作を実行します。

ただし、これら 2 つのソリューションでは、同時リクエストで次の問題が発生する傾向があります。

Redis の遅延二重削除戦略の使用方法

最初のソリューションの欠点: リクエスト 1 の場合データベースの更新操作が実行された後、キャッシュのクリアが実行される前に、リクエスト 2 が入ってキャッシュをクエリします。この時点では、キャッシュ内のデータはまだ古いデータであり、削除される前に削除されていません。により、データの問題が発生します。ただし、t1 がキャッシュ削除操作を実行した後は、後続のリクエストでキャッシュのクエリ、データのクエリ、キャッシュへの更新ができなくなります。この影響は比較的小さいです。

  1. t1 スレッドが最初にデータベースを更新します;

  2. t2 スレッド クエリがキャッシュにヒットし、古いデータを返します;

  3. t1 スレッドがデータベースを更新しました。キャッシュ キーは 5 ミリ秒以内に削除され、他のスレッドは 5 ミリ秒以内にクエリを実行すると予想されます。キャッシュされた結果は古いデータのままですが、クエリのキャッシュされた結果は 5 ミリ秒後には空になります。最新の DB 結果が Redis に再度同期されます。

  4. プロジェクトに遅延が発生するのはよくあることなので、そのような遅延がビジネスに与える影響は実際には非常に限定的です。しかし、それが発生してキャッシュの削除に失敗した場合はどうなるでしょうか?

1. 再試行を続ける ----http プロトコル インターフェイスにある場合、インターフェイスの応答が遅くなり、このインターフェイスを呼び出すときに応答タイムアウトが発生します。 mq 非同期形式による

Redis の遅延二重削除戦略の使用方法

2 番目の解決策の欠点: リクエスト 1 がキャッシュをクリアしてもデータ更新操作をまだ実行していない場合、リクエスト 2 が古いデータをクエリするために入ります。データベースと書き込み redis を入力すると、データベースと redis データの間で不整合の問題が発生します。

  • t1 スレッドは最初にキャッシュを削除します;

  • t2 スレッドはキャッシュを null として読み取り、db データをキャッシュに同期します;

  • t1 スレッドは db 内のデータを更新します;

  • t3 スレッドはキャッシュ内のデータが古いデータであることをクエリします;

3 、ソリューション処理には欠点があるため、遅延二重削除戦略を使用する必要があります。

更新操作を実行する前にキャッシュをクリアし、更新操作後に N 秒待ってキャッシュを再度クリアします。完成しました。 2 回の削除が実行され、一定の遅延が必要です

    RedisUtils.del(key);// 先删除缓存    updateDB(user);// 更新db中的数据    Thread.sleep(N);// 延迟一段时间,在删除该缓存key    RedisUtils.del(key);// 先删除缓存

4. 注意点

上記の時間 (遅延 N 秒) は、書き込み操作の時間よりも長くなります。 redis への書き込み時間が遅延時間よりも早い場合、リクエスト 1 はキャッシュをクリアしますが、リクエスト 2 のキャッシュはまだ書き込まれていないため、厄介な状況が発生します。 。 。

5. 遅延時間はどうやって決めるのですか?

業務プログラム実行時に、データの読み込みやキャッシュの書き込みなどのビジネスロジック実行の動作時間をもとに見積もります。 「遅延二重削除」は、このソリューションではキャッシュされた値を最初に削除した後、一定期間の遅延後に再度削除するためです。

以上がRedis の遅延二重削除戦略の使用方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
Redis:キャッシュ、セッション管理などRedis:キャッシュ、セッション管理などMay 01, 2025 am 12:03 AM

Redisの関数には、主にキャッシュ、セッション管理、その他の機能が含まれます。1)キャッシュ関数はメモリを介してデータを保存して読み取り速度を向上させ、eコマースWebサイトなどの高周波アクセスシナリオに適しています。 2)セッション管理関数は、分散システムでセッションデータを共有し、有効期限のあるメカニズムを通じて自動的にクレンジングします。 3)リアルタイムメッセージプッシュおよびマルチスレッドシステムおよびその他のシナリオに適した、パブリッシュサブスクライブモード、分散ロック、カウンターなどのその他の機能。

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

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

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

PhpStorm Mac バージョン

PhpStorm Mac バージョン

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

SecLists

SecLists

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

Safe Exam Browser

Safe Exam Browser

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境