ホームページ データベース Redis Redis キャッシュ雪崩、キャッシュ ブレークダウン、キャッシュ ペネトレーションとは何を意味しますか?

Redis キャッシュ雪崩、キャッシュ ブレークダウン、キャッシュ ペネトレーションとは何を意味しますか?

Mar 12, 2021 am 09:47 AM
redis キャッシュ

Redis キャッシュ雪崩、キャッシュ ブレークダウン、キャッシュ ペネトレーションとは何を意味しますか?

Redis キャッシュとは何ですか?

Redis キャッシュは、ANSIC 言語で書かれたオープンソースのログタイプの Key-Value データベースで、ネットワークをサポートし、メモリベースで永続化でき、複数の言語で API を提供します。

Redis キャッシュの役割は何ですか?

Redis キャッシュを使用すると、特にデータ クエリにおいて、アプリケーションのパフォーマンスと効率が大幅に向上します。しかし同時に、いくつかの問題ももたらします。中でも最も重要な問題はデータの整合性であり、厳密に言えばこの問題には解決策がありません。データの一貫性要件が非常に高い場合、キャッシュは使用できません。

もう 1 つの典型的な問題は、キャッシュの侵入、キャッシュなだれ、キャッシュの故障です。現在、業界には比較的人気のあるソリューションもあります。この記事は、これら 3 つの問題をより完全に解決することを目的としたものではなく、また、業界で一般的なソリューションを破壊することを目的としたものでもありません。代わりに、実際のコード操作を通じてこれら 3 つの問題現象を示します。このような理由は、これらの問題は学術的な説明だけでは頭の中に鮮明に概念を思い浮かべることが難しいためであり、実際のコードのデモンストレーションを行うことで、これらの問題への理解と理解を深めることができるからです。

キャッシュ ペネトレーション

キャッシュ ペネトレーションとは、データベースに存在してはいけないデータのクエリを指します。キャッシュを使用する通常のプロセスは、大まかに言うと、データ クエリが最初にキャッシュ クエリを実行し、キーが存在しない場合、またはキーの有効期限が切れている場合は、データベースにクエリを実行し、クエリされたオブジェクトをキャッシュに入れます。データベース クエリ オブジェクトが空の場合、キャッシュには配置されません。

#コード フロー

##1. パラメータをオブジェクトの主キー ID に渡します

#2. キーに基づいてキャッシュからオブジェクトを取得します

3. オブジェクトが空でない場合は、直接戻ります

4. オブジェクトが空の場合は、データベースをクエリします

#5. データベースからクエリされたオブジェクトが空でない場合は、それを配置しますキャッシュ内 (有効期限を設定) 想像してください。この場合、渡されたパラメーターが -1 の場合はどうなるでしょうか?この -1 は絶対に存在しないオブジェクトです。データベースは毎回クエリされ、すべてのクエリは空になり、キャッシュは毎回実行されるわけではありません。悪意のある攻撃があった場合、この脆弱性が悪用されてデータベースに圧力をかけたり、データベースを破壊したりする可能性があります。 UUID を使用した場合でも、存在しない KEY を見つけて攻撃することは容易です。

私の作業では、エディターは Null 値をキャッシュする方法を使用します ([コード プロセス] のステップ 5)。データベースからクエリされたオブジェクトが空の場合、それもキャッシュに入れられます。設定されたキャッシュのみ 有効期限は短くなり、たとえば 60 秒に設定されます。

(学習ビデオ共有:

redis ビデオ チュートリアル

)

キャッシュ アバランチ

キャッシュ アバランチとは、特定の時間セグメントを指します。キャッシュの集中期限切れ。 雪崩の理由の 1 つは、私がこの記事を書いている時点ではダブル 12 の真夜中近くであり、まもなくパニック買いの波が起こるでしょう。この製品の波はさらに集中的に投入されるでしょう。 . 1 時間を想定したキャッシュ。その後、午前 1 時に、この製品バッチのキャッシュの有効期限が切れました。この製品バッチに対するアクセス クエリはすべてデータベースに送信され、データベースに定期的な圧力ピークが生成されます。

編集者が電子商取引プロジェクトに取り組んでいるとき、彼は通常、さまざまなカテゴリの商品を使用し、それらをさまざまな期間にわたってキャッシュします。同じカテゴリの製品にランダムな要素を加えたもの。これにより、キャッシュの有効期限を可能な限り分散することができ、また、人気のあるカテゴリの商品のキャッシュ時間が長くなり、人気のないカテゴリの商品のキャッシュ時間が短くなり、キャッシュサービスのリソースを節約することもできます。

実際には、集中有効期限切れはそれほど致命的ではありませんが、より致命的なキャッシュ雪崩は、キャッシュ サーバーのノードがダウンしているか、ネットワークから切断されている場合に起こります。自然に発生するキャッシュなだれは、一定期間に集中的にキャッシュを作成する必要があるため、データベースはその時の圧力に耐えることができ、データベースもその圧力に耐えることができます。これはデータベースに対する定期的な負荷に他なりません。キャッシュ サービス ノードのダウンタイムはデータベース サーバーに予期せぬ圧力をかけ、データベースが瞬時に超過してしまう可能性が非常に高くなります。

キャッシュ ブレークダウン

キャッシュ ブレークダウンとは、非常にホットで常に大量の同時実行を実行するキーを指します。大規模な同時実行では、キーの有効期限が切れたときに、このポイントにアクセスすることに重点が置かれます。 、継続的に大規模な同時実行がキャッシュを突破し、データベースに直接リクエストすることは、バリアに穴を開けるようなものです。 編集者が電子商取引プロジェクトに取り組んでいたとき、この商品は「注目のアイテム」になりました。

実際には、ほとんどの場合、この種の爆発がデータベース サーバーに圧倒的な圧力を引き起こすことは困難です。このレベルに達している企業はほとんどありません。そのため、プラグマティックエディターでは主要製品についてはキャッシュが期限切れにならないよう早めの準備を行っています。たとえ一部の商品がそれ自体で人気になったとしても、期限を設定しないように設定するだけで済みます。

簡単に言うと、ミューテックス キーのミューテックス ロックは実際には役に立ちません。

学習チュートリアルの共有:

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コマンドを使用して、ロックが不要になったときにロックを削除します。

Redisのソースコードを読み取る方法 Redisのソースコードを読み取る方法 Apr 10, 2025 pm 08:27 PM

Redisソースコードを理解する最良の方法は、段階的に進むことです。Redisの基本に精通してください。開始点として特定のモジュールまたは機能を選択します。モジュールまたは機能のエントリポイントから始めて、行ごとにコードを表示します。関数コールチェーンを介してコードを表示します。 Redisが使用する基礎となるデータ構造に精通してください。 Redisが使用するアルゴリズムを特定します。

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

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

Redisでデータ損失を解決する方法 Redisでデータ損失を解決する方法 Apr 10, 2025 pm 08:24 PM

Redisデータ損失の原因には、メモリの障害、停電、人的エラー、ハードウェアの障害が含まれます。ソリューションは次のとおりです。1。RDBまたはAOF持続性を使用してデータをディスクに保存します。 2。高可用性のために複数のサーバーにコピーします。 3。Hawith redis sentinelまたはredisクラスター。 4.データをバックアップするスナップショットを作成します。 5.永続性、複製、スナップショット、監視、セキュリティ対策などのベストプラクティスを実装します。

See all articles