最近 redis を使っていて、とても便利だと感じているのですが、インメモリ データベースを選択する際に、どのような場合に redis を選択し、どのような場合に memcache を選択すればよいのか迷っています。そこで、redis の作者 (stackoverflow 上) が提供している次の関連情報を見つけました。 パフォーマンスについてはあまり気にする必要はありません。Redis は小さな値ではコアごとに高速ですが、memcached はクライアントの助けを借りずに単一の実行ファイルと TCP ポートで複数のコアを使用できます。また、100k オーダーの大きな値では memcached の方が高速です。Redis は最近大きな値に関して大幅に改善されましたが (不安定なブランチ)、このユース ケースでは依然として memcached の方が高速です。ここでのポイントは、どちらも、提供できる 1 秒あたりのクエリのボトルネックにはならない可能性が高いということです。 メモリ使用量に注意する必要があります。単純なキーと値のペアの場合、memcached の方がメモリ効率が高くなります。Redis ハッシュを使用する場合、Redis の方がメモリ効率が高くなります。使用例によって異なります。 永続性とレプリケーションは、Redis でのみ利用可能な 2 つの機能です。キャッシュを構築することが目的の場合でも、アップグレードや再起動後もデータが残っていると便利です。 必要な操作の種類に注意する必要があります。Redis には複雑な操作が多数あり、キャッシュの使用例だけを考慮しても、多くの場合、クライアント側でデータを処理する必要なく (大量の I/O が必要になる場合があります)、1 回の操作でより多くの操作を実行できます。これらの操作は、多くの場合、単純な GET および SET と同じくらい高速です。そのため、GET/SET だけでなく、より複雑な操作が必要な場合、Redis が非常に役立ちます (タイムライン キャッシュを考えてみてください)。 あるネットユーザーは次のように翻訳した[1]。 パフォーマンスにあまり重点を置く必要はありません。 Redis は 1 つのコアのみを使用しますが、Memcached は複数のコアを使用できるため、各コアに小さなデータを保存する場合、平均して Redis の方が Memcached よりもパフォーマンスが高くなります。 100k を超えるデータの場合、Memcached は Redis よりもパフォーマンスが優れています。Redis は最近、ビッグデータの保存用に最適化されましたが、それでも Memcached よりわずかに劣ります。とはいえ、結論としては、どちらを使用しても、1 秒あたりのリクエスト数はボトルネックにならないということです。 メモリ使用量に注意する必要があります。キー値などの単純なデータストレージの場合、memcache の方がメモリ使用率が高くなります。ハッシュ構造を使用すると、Redis のメモリ使用量が高くなります。もちろん、これらすべては特定のアプリケーション シナリオによって異なります。 データの永続性とマスタースレーブレプリケーションに注意を払う必要がある場合、これらの 2 つの機能を備えているのは 必要な操作に注意する必要があります。 Redis は多くの複雑な操作をサポートしており、メモリ使用量だけを考慮しても、データをクライアントに読み込むことなく (多くの IO 操作が必要)、1 回の操作で多くの操作を実行できる場合がよくあります。これらの複雑な操作は基本的に純粋な GET および POST 操作と同じくらい高速なので、GET/SET 以外の操作が必要な場合には Redis が大きな役割を果たします。 2 つのどちらを選択するかは、特定のアプリケーション シナリオによって異なります。キャッシュするデータがキーと値のような単純な構造である場合、私のプロジェクトでは、安定性と信頼性が十分にある memcache を使用しています。保存やソートなどの一連の複雑な操作が含まれる場合、Redis が最適な選択であることに疑いの余地はありません。 Redis と memcache の違いについては、記録のために関連するいくつかの記述を次に示します。 redisとmemecacheの違いは次のとおりです[2]。 1. 保管方法: まとめると、永続性要件やデータ構造と処理の高度な要件があるアプリケーションの場合は Redis を選択し、その他の単純なキー/値ストレージの場合は memcache を選択してください。 RedisとMemcacheの比較と選び方に関するこの記事はこれで終わりです。RedisとMemcacheのより関連性の高い比較コンテンツについては、123WORDPRESS.COMの過去の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後とも123WORDPRESS.COMをよろしくお願いいたします。 |
<<: JavaScript ファイルの読み込みとブロックの問題: パフォーマンス最適化のケーススタディ
この記事では、例を使用して、MySQL サーバーのスレッド数を表示する方法について説明します。ご参考...
mysqlのrootアカウント、普段はlocalhostか127.0.0.1で接続しています。会社の...
序文この記事は、最も人気のある言語で最も退屈な基礎知識を説明することを目的としていますこのトピックは...
一般的な演算子と JavaScript の演算子の概要カテゴリオペレーター算術演算子+、–、*、/、...
今日、ある人がウェブサイト開発プロジェクトについて話をしてくれました。具体的な要件について話すと、「...
ドロップテーブルドロップはテーブル情報を直接削除するため、最も高速ですが、データを取得することはでき...
border-radius:10px; /* すべての角は半径 10px で丸められます*/ bor...
成果を達成する実装コードhtml <base href="https://s3-us...
table タグと td タグに境界線を追加すると、デフォルトでは次のように二重境界線が使用されます...
iframe の使い方:コードをコピーコードは次のとおりです。 <DIV align=cent...
序文小規模なプログラムの開発では、リストをスクロールして表示する必要性に遭遇することがよくあります。...
この記事では、例を使用して MySQL トリガーの簡単な使用方法を説明します。ご参考までに、詳細は以...
目次効果ドキュメント最初のステップステップ2ステップ3ソースコード効果ドキュメント最初のステップta...
1. PVとIPの統計一日のPV(ページビュー)をカウントする cat access.log | ...
目次01 コンテナの一貫性02 レイヤーの概念03 レイヤードデザインの利点今日はコンテナ レイヤー...