Redis と Memcached の比較、および CentOS でのインストールと構成
Redis について学ぶ
Redis は、オープンソースのネットワーク対応のメモリベースのキーと値のデータベースであり、ANSI C で記述されており、複数の言語で API を提供しています。開始するのはほとんど難しくなく、必要な作業は 1 つだけです。数分でインストールが完了し、アプリケーションがスムーズに動作し始めるようになります。言い換えれば、わずかな時間と労力を投資するだけで、すぐに優れたパフォーマンスの向上を得ることができ、非常にシンプルなキャッシュ ソリューションであることを意味します。サポートされる値の型は文字列に限定されず、マスターとスレーブの同期、データの永続化などもサポートされます。Redis が最も人気のある Key-Value ストレージ データベースであると誰もが考えていますが、Memcached についてはどうなのかと疑問に思う人もいるでしょう。
Redis VS Memcached
まず、DB-Engines.com のデータベース ランキングを確認しました。Redis は 9 位、Memcached は 23 位、Key-value ストアは 2 位でした。もちろんこれには何の意味もありません。
Redis は、String、Hash、List、Set などのより多くのデータ型をサポートします。Memcached は 1 つの String データ型のみをサポートします。
Redis は、Multi/Watch/Exec などのコマンドを通じてトランザクションの概念をサポートし、コマンドのバッチをアトミックに実行できます。Memcached のアプリケーション モードでは、インクリメント/デクリメントなどのアトミック操作コマンドを除き、トランザクションはサポートされません。
Redis は、マスター/スレーブ同期バックアップを実現するためにマスター/スレーブ モードでサーバーを構成できますが、2 つの永続化ソリューションのみをサポートします。Memcached は、保存されたデータの有効性を保証せず、データの永続化も実行しません。もちろん、これには何の意味もありません。
この世界のすべてのものには常に意味があります。 Memcached の内部メモリ管理メカニズムは Redis ほど複雑ではありませんが、Memcached はメタデータの処理時に消費するメモリ リソースが比較的少ないため、より実用的で効率的です。また、その設計傾向と比較的シンプルなため、水平拡張の点で Redis よりも優れています。機能の設定。たとえば、文字列または HTML ページをキャッシュする場合は、Memcached を使用する方が比較的適切です。
CentOS に Redis をインストールします
1. Redis をダウンロード、解凍してインストールします。これは、公式 Web サイトからダウンロードした最新バージョンです (私はこの方法が好きです)。
wget http://download.redis.io/releases/redis-3.2.5.tar.gztar xzf redis-3.2.5.tar.gz mv redis-3.2.5 /usr/local/redis
上記の mv redis-3.2.5 /usr/local/redis コマンドは、Redis インストール ファイルをインストール ディレクトリに移動します。 もちろん、このディレクトリはカスタマイズできます。
2. ディレクトリに移動し、コンパイルしてインストールします
cd /usr/local/redis make make install
この時点で、redis-server、redis-cli、およびその他の実行可能スクリプトが /usr/local/bin/ ディレクトリに表示されます。そうでない場合は、解凍したディレクトリに移動してコピーしてください。
cd /usr/local/bin/
3. redis.conf を設定します
/usr/local/redis ディレクトリに戻り、次を設定します:
cd ../redis vim redis.conf
変更する場所は 2 つあります。ここでは、バインドしてデーモン化するだけで十分です。
ここでバインドを設定するときは注意してください。現時点では、127.0.0.1 のみが接続でき、他の LAN には接続できません。したがって、LAN 内で接続できるように複数の IP を設定する必要があります。
daemonize は、Redis をバックグラウンドで起動するかどうかを設定します。デフォルトは no です。通常、Redis はサービスとして起動する必要があるため、ここでは yes に設定します。
修改完后,保存退出。
4.启动
cd /usr/local/bin/ redis-server /usr/local/redis/redis.conf netstat -anp | grep 6379
5.测试一下
这里用命令行模式连接上 Redis 进行一个简单的设置、获取缓存测试。
redis-cli #连接 Redis ,默认是本机的。 keys * #查看现在所有 keyset name mafly #设置一个key为`name`,value为`mafly`的缓存对象。 get name #获取key为`name`的缓存
6.关闭 Redis
redis-cli shutdown
通过 netstat 可以看出来端口已经是TIME_WAIT状态了。
总结一下
经过这次安装配置 Redis 的过程,也让我更加了解了一下 Memcached ,也更明白了这两种最流行的 Key-Value 缓存服务的优劣势,当然大多数都是通过网络获取,在实际运用中怎样也在监测中。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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

Redisはハッシュテーブルを使用してデータを保存し、文字列、リスト、ハッシュテーブル、コレクション、注文コレクションなどのデータ構造をサポートします。 Redisは、スナップショット(RDB)を介してデータを維持し、書き込み専用(AOF)メカニズムを追加します。 Redisは、マスタースレーブレプリケーションを使用して、データの可用性を向上させます。 Redisは、シングルスレッドイベントループを使用して接続とコマンドを処理して、データの原子性と一貫性を確保します。 Redisは、キーの有効期限を設定し、怠zyな削除メカニズムを使用して有効期限キーを削除します。

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

Redisは、メッセージミドルウェアとして、生産消費モデルをサポートし、メッセージを持続し、信頼できる配信を確保できます。メッセージミドルウェアとしてRedisを使用すると、低遅延、信頼性の高いスケーラブルなメッセージングが可能になります。
