ホームページ データベース Redis Redis はなぜそれほど速いのでしょうか?

Redis はなぜそれほど速いのでしょうか?

May 30, 2023 pm 08:27 PM
redis

Redis は、キーと値のペアに基づく NoSQL データベースです。Redis の値は、文字列、ハッシュ、リスト、セット、zset、ビットマップ、HyperLogLog などのさまざまなデータ構造とアルゴリズムで構成できます。 Redis には、キーの有効期限、パブリッシュとサブスクライブ、トランザクション、Lua スクリプト、センチネル、クラスターなど、多くの機能があります。

公式パフォーマンス データによると、Redis は非常に高速でコマンドを実行でき、QPS は 100,000 以上に達することがあります。そこでこの記事では、Redis がどこが速いのか、主に次の点を含めて紹介します:

1. 開発言語

現在、私たちはプログラミングに高級言語を使用しています。 、Java、Pythonなど。 C言語というと古いイメージがあるかもしれませんが、とても便利で、なんといってもUnixシステムはCで実装されているため、C言語はオペレーティングシステムに非常に近い言語です。 RedisはC言語で開発されているため、実行が高速になります。

もう 1 つ、学生は C 言語の学習に重点を置くべきです。C 言語はコンピュータのオペレーティング システムをより深く理解するのに役立ちます。高級言語を学んだ後は、下位層に注意を払う必要がなくなるなどとは考えないでください。借りた借金は必ず返済しなければなりません。ここでは、より難しい本である「Deep Understanding of Computing System」をお勧めします。

2. 純粋なメモリ アクセス

Redis はメモリを使用してすべてのデータを保存するため、通常の操作中にデータ以外の同期のためにディスクからデータを読み取る必要はありません。 IO の数は 0 です。メモリの応答時間は約 100 ナノ秒で、これは Redis の高速性の重要な基盤です。まずは CPU の速度を見てみましょう:

Redis はなぜそれほど速いのでしょうか?

私のコンピュータを例にとると、その主な周波数は 3.1G で、これは 1 秒あたり 31 億命令を実行できることを意味します。 CPU の世界観の処理速度は非常に遅く、それに比べてメモリは 100 倍、ディスクは 100 万倍遅いのですが、これは速いと思いますか?

「コンピュータ システムの徹底理解」から画像を借用しましたが、これは典型的なメモリ階層を示しています。L0 層では、CPU は 1 クロック サイクルでアクセスでき、SRAM ベースのキャッシュはこれらは数 CPU クロック サイクルでアクセスでき、次に DRAM ベースのメイン メモリには数十から数百クロック サイクルでアクセスできます。

Redis はなぜそれほど速いのでしょうか?

3. シングル スレッド

シングル スレッドはアルゴリズムの実装を簡素化できますが、同時実行の実装が難しいだけではありません。データ構造も複雑ですが、テストも難しく、非常に面倒です。サーバーサイド開発では、ロックとスレッド切り替えは通常パフォーマンスを低下させる原因となるため、単一スレッドを使用することでそれらによる消費を回避できます。もちろん、シングルスレッドにも欠点があり、それは Redis の悪夢でもあるブロッキングです。コマンドの実行が長すぎると、他のコマンドがブロックされます。これは Redis にとって非常に致命的であるため、Redis は高速実行シナリオ用のデータベースです。

Redis に加えて、Node.js もシングルスレッドであり、Nginx もシングルスレッドですが、どちらも高性能サーバーのモデルです。

4. ノンブロッキング マルチチャネル I/O 多重化メカニズム

その前に、When read またはwrite は、特定のファイル記述子 (ファイル記述子 FD) の読み取りまたは書き込みを行います。データが受信されない場合、データが受信されるまでスレッドは一時停止されます。

ブロッキング モデルは理解しやすいですが、複数のクライアント タスクを処理する必要がある場合には使用されません。

Redis はなぜそれほど速いのでしょうか?

#I/O 多重化とは、実際には、複数の接続を同じプロセスで管理できることを意味します。マルチチャネルとはネットワーク接続を指し、多重化は同じスレッドにすぎません。ネットワークサービスにおいて、I/O多重化の役割は複数の接続イベントを一度に業務コードに通知することであり、処理方法は業務コードによって決まります。

I/O多重化モデルにおいて最も重要な関数呼び出しはI/O多重化機能であり、このメソッドは複数のファイルディスクリプタ(fd)の読み書きを同時に監視することができます。 fd が読み取り/書き込み可能である場合、このメソッドは読み取り/書き込み可能な fd の数を返します。

Redis はなぜそれほど速いのでしょうか?

Redis は、I/O 多重化テクノロジの実装として epoll を使用しており、Redis 独自のイベント処理モデルは、時間を無駄にすることなく epoll の読み取り、書き込み、クローズなどのイベントを変換します。ネットワーク I/O について。複数の FD の読み取りと書き込みの監視を実現し、パフォーマンスを向上させます。

Redis はなぜそれほど速いのでしょうか?

鮮やかな例を挙げてみましょう。たとえば、TCP サーバーは 20 個のクライアント ソケットを処理します。

計画: 逐次処理。ネットワーク カードのせいで最初のソケットのデータ読み取りが遅い場合、それがブロックされると、残りのソケットが台無しになります。

プラン B: ソケット リクエストごとにクローン サブプロセスを作成します。言うまでもなく、各プロセスは大量のシステム リソースを消費します。プロセスの切り替えだけでも、オペレーティング システムに十分な負担がかかります。

C スキーム (I/O 多重化モデル、epoll): ユーザーソケットに対応する fd を epoll に登録します (実際にサーバーとオペレーティングシステム間で受け渡されるのはソケットの fd ではなく、fd_set のデータ構造です) )、そして epoll どのソケットを読み取り/書き込みする必要があるかを指示するだけで、アクティブで変化するソケット fd を処理するだけで済みます。

この方法では、epoll が呼び出された場合にのみプロセス全体がブロックされ、顧客メッセージの送受信はブロックされません。

以上が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)

Windows 11 10.0.22000.100 のインストール時の 0x80242008 エラーの解決策 Windows 11 10.0.22000.100 のインストール時の 0x80242008 エラーの解決策 May 08, 2024 pm 03:50 PM

1. [スタート]メニューを起動し、[cmd]と入力し、[コマンドプロンプト]を右クリックし、[管理者として実行]を選択します。 2. 次のコマンドを順番に入力します (注意してコピーして貼り付けてください): SCconfigwuauservstart=auto、Enter キーを押す SCconfigbitsstart=auto、Enter キーを押す SCconfigcryptsvcstart=auto、Enter キーを押す SCconfigtrustedinstallerstart=auto、Enter キーを押す SCconfigwuauservtype=share、Enter キーを押す netstopwuauserv 、enter netstopcryptS を押す

Golang API のキャッシュ戦略と最適化 Golang API のキャッシュ戦略と最適化 May 07, 2024 pm 02:12 PM

GolangAPI のキャッシュ戦略により、パフォーマンスが向上し、サーバーの負荷が軽減されます。一般的に使用される戦略は、LRU、LFU、FIFO、TTL です。最適化手法には、適切なキャッシュ ストレージの選択、階層型キャッシュ、無効化管理、監視とチューニングが含まれます。実際には、データベースからユーザー情報を取得する API を最適化するために LRU キャッシュが使用されます。それ以外の場合は、データベースからデータを取得した後にキャッシュを更新できます。

PHP 開発におけるキャッシュ メカニズムとアプリケーションの実践 PHP 開発におけるキャッシュ メカニズムとアプリケーションの実践 May 09, 2024 pm 01:30 PM

PHP 開発では、キャッシュ メカニズムにより、頻繁にアクセスされるデータがメモリまたはディスクに一時的に保存され、データベース アクセスの数が削減され、パフォーマンスが向上します。キャッシュの種類には主にメモリ、ファイル、データベース キャッシュが含まれます。キャッシュは、組み込み関数またはサードパーティのライブラリ (cache_get() や Memcache など) を使用して PHP に実装できます。一般的な実用的なアプリケーションには、データベース クエリ結果をキャッシュしてクエリ パフォーマンスを最適化したり、ページ出力をキャッシュしてレンダリングを高速化したりすることが含まれます。キャッシュ メカニズムにより、Web サイトの応答速度が効果的に向上し、ユーザー エクスペリエンスが向上し、サーバーの負荷が軽減されます。

Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法_Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法 Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法_Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法 May 08, 2024 pm 05:10 PM

まず、システム言語を簡体字中国語表示に設定して再起動する必要があります。もちろん、以前に表示言語を簡体字中国語に変更したことがある場合は、この手順をスキップできます。次に、レジストリ regedit.exe の操作を開始し、左側のナビゲーション バーまたは上部のアドレス バーで HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlNlsLanguage に直接移動し、InstallLanguage キーの値と Default キーの値を 0804 に変更します (英語に変更する場合)。まずシステムの表示言語を en-us に設定し、システムを再起動してから、すべてを 0409 に変更します) この時点でシステムを再起動する必要があります。

PHP 配列のページネーションで Redis キャッシュを使用するにはどうすればよいですか? PHP 配列のページネーションで Redis キャッシュを使用するにはどうすればよいですか? May 01, 2024 am 10:48 AM

Redis キャッシュを使用すると、PHP 配列ページングのパフォーマンスを大幅に最適化できます。これは、次の手順で実現できます。 Redis クライアントをインストールします。 Redisサーバーに接続します。キャッシュ データを作成し、データの各ページをキー「page:{page_number}」を持つ Redis ハッシュに保存します。キャッシュからデータを取得し、大規模な配列での高コストの操作を回避します。

Win11でダウンロードしたアップデートファイルの探し方_Win11でダウンロードしたアップデートファイルの場所を共有する Win11でダウンロードしたアップデートファイルの探し方_Win11でダウンロードしたアップデートファイルの場所を共有する May 08, 2024 am 10:34 AM

1. まず、デスクトップ上の[このPC]アイコンをダブルクリックして開きます。 2. 次に、マウスの左ボタンをダブルクリックして [C ドライブ] に入ります。システム ファイルは通常、自動的に C ドライブに保存されます。 3. 次に、C ドライブで [windows] フォルダーを見つけ、ダブルクリックしてに入ります。 4. [windows]フォルダーに入ったら、[SoftwareDistribution]フォルダーを見つけます。 5. 入力後、win11 のダウンロード ファイルとアップデート ファイルがすべて含まれている [ダウンロード] フォルダーを見つけます。 6. これらのファイルを削除したい場合は、このフォルダー内で直接削除してください。

PHP Redis キャッシュ アプリケーションとベスト プラクティス PHP Redis キャッシュ アプリケーションとベスト プラクティス May 04, 2024 am 08:33 AM

Redis は、高性能のキー/値キャッシュです。 PHPRedis 拡張機能は、Redis サーバーと対話するための API を提供します。 Redis に接続し、データを保存および取得するには、次の手順を使用します。 接続: Redis クラスを使用してサーバーに接続します。ストレージ: set メソッドを使用してキーと値のペアを設定します。取得: get メソッドを使用してキーの値を取得します。

Docker環境にPECLを使用して拡張機能をインストールするときにエラーが発生するのはなぜですか?それを解決する方法は? Docker環境にPECLを使用して拡張機能をインストールするときにエラーが発生するのはなぜですか?それを解決する方法は? Apr 01, 2025 pm 03:06 PM

エラーの原因とソリューションPECLを使用してDocker環境に拡張機能をインストールする場合、Docker環境を使用するときに、いくつかの頭痛に遭遇します...

See all articles