目次
1. Redis バージョンの反復
ホームページ データベース Redis Redis がシングルスレッドを選択するのはなぜですか?

Redis がシングルスレッドを選択するのはなぜですか?

May 30, 2023 pm 01:01 PM
redis

1. Redis バージョンの反復

Redis がシングルスレッドを選択するのはなぜですか?

##Redis2.6、lua スクリプトをサポート;

Redis3.0、クラスターをサポート;

Redis4 .0、ハイブリッド永続性、マルチスレッドの非同期削除;

Redis5.0、コア コードの再構築;

Redis6.0、マルチスレッド IO;

Redis7. 0 , Function, Multi-part-AOF;

2. Redis 4.0 より前は、Redis が常にシングル スレッドを使用していた理由は何ですか?

1. Redis は、開発とメンテナンスを容易にするためにシングル スレッド モデルを採用しています;

2. シングル スレッド モデルは、IO 多重化とノンブロッキング IO を通じて複数のクライアント リクエストを同時に処理することもできます。

3. Redis の場合、主なパフォーマンスのボトルネックは CPU ではなくメモリとネットワークです;

3. Redis6.0 ではマルチスレッドが導入されます

Redis6.0 より前は、Redisネットワーク IO 処理から実際の読み取りおよび書き込みコマンドの処理まではすべてシングルスレッドですが、データの削除とデータの永続化にはマルチスレッドが使用されます。

Redis のパフォーマンスのボトルネックは主にネットワーク IO であるため、Redis 6.0 以降では、ネットワーク リクエストの処理の並列性を向上させるために、複数の IO スレッドを使用してネットワーク リクエストを処理するようになりました。

4. Redis メインスレッドと IO スレッドはどのようにリクエストを完了しますか?

Redis がシングルスレッドを選択するのはなぜですか?

1. サーバーとクライアント間のソケット接続を確立します。
メイン スレッドは、接続を確立し、ソケットをグローバルに配置する責任があります。待機キュー メインスレッドがラウンドを通過 クエリメソッドがソケット接続を IO スレッドに割り当てます。

2. IO スレッドはリクエストを読み取り、解析します
メイン スレッドがソケットを IO スレッドに割り当てると、メイン スレッドはブロッキング状態になり、IO スレッドがクライアントの処理を完了するまで待機します。このとき、複数の IO スレッドが並行して処理されます。

3. メインスレッドはリクエストコマンドを実行します
IO スレッドがリクエストを解析した後も、メインスレッドはこれらのコマンドをシングルスレッド方式で実行します。

4. IO スレッドはソケットに書き戻し、メインスレッドはグローバル キューをクリアします
メインスレッドがリクエスト コマンドの実行を終了すると、結果がバッファに書き込まれます、メインスレッドはブロッキング状態に入り、IO を待ちます。スレッドは結果をソケットに書き込み、クライアントに返します。

ソケットを書き戻した後、メインスレッドはグローバルキューをクリアします。

5.IO多重化とは何ですか?

IO 多重化 (同期 IO モデル) は、複数のファイル ハンドルを監視するスレッドを実装します。ファイル ハンドルの準備が完了すると、対応するアプリケーションに、対応する読み取りおよび書き込み操作を実行するように通知できます。ファイル ハンドルの準備ができていない場合、プログラムはブロッキング状態に入り、CPU リソースを解放します。

1. IO、オペレーティング システム レベルは、カーネル モードとユーザー モード間のデータの読み取りおよび書き込み操作を指します;

2. マルチチャネル、複数のクライアント ソケット接続;

3. 多重化、スレッドの多重化;

4. IO 多重化、単一のスレッドを使用して複数のクライアント ソケット接続を同時に処理;

クライアント ソケットの対応 ファイル記述子 FileDescriptor が登録されますepoll では、大量の無駄な操作を避けるために、どのソケットにメッセージがあるかを監視します。

現時点では、ソケットはノンブロッキング モードを採用しています。プロセス全体は、selecting、poll、epoll が呼び出されたときのみブロックされます。クライアント メッセージの受信時にはブロックされず、プロセスはフル活用されます。 . このモードは一般にイベント駆動と呼ばれるもので、リアクター反応モードです。

epoll を使用する最終的な目標は、サーバーのスループットを向上させることです。

IO 多重化と epoll 関数は、**「なぜ 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)

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 メソッドを使用してキーの値を取得します。

さまざまな PHP バージョンで関数のパフォーマンスを最適化するにはどうすればよいですか? さまざまな PHP バージョンで関数のパフォーマンスを最適化するにはどうすればよいですか? Apr 25, 2024 pm 03:03 PM

さまざまな PHP バージョンで関数のパフォーマンスを最適化する方法には、分析ツールを使用して関数のボトルネックを特定すること、オペコード キャッシュを有効にするか外部キャッシュ システムを使用すること、型アノテーションを追加してパフォーマンスを向上させること、および PHP バージョンに応じて適切な文字列連結およびソート アルゴリズムを選択することなどが含まれます。

See all articles