ホームページ データベース Redis Redis メモリがいっぱいになった場合の問題を解決する方法

Redis メモリがいっぱいになった場合の問題を解決する方法

Jul 05, 2019 pm 03:13 PM

Redis メモリがいっぱいになった場合の問題を解決する方法

Redis メモリがいっぱいです 解決策:

1、メモリを増やします。

2、メモリ排除戦略を使用します。

3、Redis クラスター。

2 と 3 に注目:

2 番目の点:

redis 構成ファイルの maxmemory パラメーターで、使用可能な最大メモリ サイズ (バイト) を制御できることがわかっています。

それでは、必要なメモリが maxmemory を超えた場合はどうすればよいでしょうか?

このとき、構成ファイル内の maxmemory-policy が機能します。

デフォルト値は noeviction です。

以下に、使用可能なメモリが不十分な場合に Redis キーを削除するための除外ルールを示します。

ルールの説明:

1. volatile-lru

LRU アルゴリズムを使用してキーを削除します (生存時間が設定されているキーのみ)

2. allkeys-lru

LRU アルゴリズムを使用してキーを削除します

3、volatile-random

キーをランダムに削除します (生存時間が設定されているキーのみ)

4. allkeys-random

キーをランダムに削除します

#5.volatile-ttl

##最新の生存時間を持つキーを削除します

6.noeviction

キーは削除しないでください。エラーのみを返します。

LRU アルゴリズム、最も最近使用されていないアルゴリズム、最も最近使用されていないアルゴリズム。つまり、最も最近使用されていないキーがデフォルトで削除されます。

しかし、注意しなければならないことが 1 つあります。 Redis は、すべてのキーのうち最も最近使用されていないキーを正確に削除するのではなく、ランダムに 3 つのキーを選択し、これら 3 つのキーのうち最も最近使用されていないキーを削除します。

次に、数値 3 も設定でき、対応する場所は構成ファイルの maxmeory-samples です。

3. クラスターの実行方法

Redis はのみサポートしていますシングルインスタンス、メモリ 通常最大10~20GB。 100 ~ 200 GB のメモリを備えたシステムの場合、クラスタリングを通じてサポートする必要があります。

Redis クラスタリングには、クライアント シャーディング、プロキシ シャーディング、RedisCluster の 3 つの方法があります (これについては後の記事で詳しく説明します。)

1. クライアント シャーディング

ルーティングの実装ビジネスコード経由

メリット: シャーディングアルゴリズムを自分で制御でき、プロキシよりもパフォーマンスが優れています

デメリット: 維持コストが高く、拡張/縮小などの運用保守作業が必要研究と開発

2. エージェント シャーディング

エージェント プログラムはビジネス プログラムからデータ リクエストを受け取り、ルーティング ルールに従ってこれらのリクエストを正しい Redis インスタンスに分散します。そしてそれらをビジネスプログラムに戻します。 Twemproxy や Codis などのミドルウェアを使用して実装されます。

メリット: 運用保守が容易、Redis インスタンスへの接続方法を気にする必要がない

デメリット: パフォーマンスを消費する(約20%)、スムーズに拡張できない/縮小し、データを移行するためにスクリプトを実行する必要があるため、不便です (Codis は自動リバランスを実現するために Twemproxy に基づいてプリシャーディングを最適化および実装します)。

3. Redis クラスター

利点: 公式クラスター ソリューション、セントラル ノードなし、クライアントへの直接接続、優れたパフォーマンス

欠点: ソリューションが重すぎるため、実行できませんスムーズな拡張/縮小には、対応するスクリプトの実行が必要ですが、これは不便で、新しすぎ、対応する成熟したソリューション ケースがありません

Redis 関連の知識の詳細については、

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

AI Hentai Generator

AI Hentai Generator

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クラスターでシャードキーを選択するにはどうすればよいですか? Mar 17, 2025 pm 06:55 PM

この記事では、Redisクラスターでシャードキーを選択し、パフォーマンス、スケーラビリティ、データ分布への影響を強調しています。重要な問題には、データ分布の確保、アクセスパターンの調整、一般的な間違いの回避lが含まれます。

Redisで認証と承認を実装するにはどうすればよいですか? Redisで認証と承認を実装するにはどうすればよいですか? Mar 17, 2025 pm 06:57 PM

この記事では、Redisでの認証と承認の実装について説明し、ACLSを使用し、Redisを保護するためのベストプラクティスの有効化に焦点を当てています。また、Redisセキュリティを強化するためのユーザー許可とツールの管理をカバーしています。

ジョブキューとバックグラウンド処理にRedisを使用するにはどうすればよいですか? ジョブキューとバックグラウンド処理にRedisを使用するにはどうすればよいですか? Mar 17, 2025 pm 06:51 PM

この記事では、ジョブキューとバックグラウンド処理にRedisを使用し、セットアップ、ジョブの定義、実行の詳細を使用しています。アトミックオペレーションやジョブの優先順位付けなどのベストプラクティスをカバーし、Redisが処理効率を高める方法を説明します。

Redisでキャッシュ無効化戦略を実装するにはどうすればよいですか? Redisでキャッシュ無効化戦略を実装するにはどうすればよいですか? Mar 17, 2025 pm 06:46 PM

この記事では、時間ベースの有効期限、イベント駆動型の方法、バージョン化など、Redisでキャッシュの無効化を実装および管理するための戦略について説明します。また、キャッシュの有効期限と監視とオートマットのツールのベストプラクティスもカバーしています

Redisクラスターのパフォーマンスを監視するにはどうすればよいですか? Redisクラスターのパフォーマンスを監視するにはどうすればよいですか? Mar 17, 2025 pm 06:56 PM

記事では、Redis CLI、Redis Insight、DatadogやPrometheusなどのサードパーティソリューションなどのツールを使用して、Redisクラスターのパフォーマンスと健康を監視しています。

Pub/SubメッセージングにRedisを使用するにはどうすればよいですか? Pub/SubメッセージングにRedisを使用するにはどうすればよいですか? Mar 17, 2025 pm 06:48 PM

この記事では、Pub/サブメッセージング、セットアップ、ベストプラクティスのカバー、メッセージの信頼性の確保、監視のパフォーマンスにRedisを使用する方法について説明します。

Webアプリケーションのセッション管理にRedisを使用するにはどうすればよいですか? Webアプリケーションのセッション管理にRedisを使用するにはどうすればよいですか? Mar 17, 2025 pm 06:47 PM

この記事では、Webアプリケーションでのセッション管理にRedisを使用すること、セットアップの詳細、スケーラビリティやパフォーマンスなどの利点、セキュリティ対策について説明します。

共通の脆弱性に対してRedisを保護するにはどうすればよいですか? 共通の脆弱性に対してRedisを保護するにはどうすればよいですか? Mar 17, 2025 pm 06:57 PM

記事では、強力なパスワード、ネットワークバインディング、コマンドの無効化、認証、暗号化、更新、監視に焦点を当てた脆弱性に対するRedisの保護について説明します。

See all articles