検索
ホームページデータベースRedisRedis がシングルスレッドを選択するのはなぜですか?

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 までご連絡ください。
es和redis区别es和redis区别Jul 06, 2019 pm 01:45 PM

Redis是现在最热门的key-value数据库,Redis的最大特点是key-value存储所带来的简单和高性能;相较于MongoDB和Redis,晚一年发布的ES可能知名度要低一些,ES的特点是搜索,ES是围绕搜索设计的。

一起来聊聊Redis有什么优势和特点一起来聊聊Redis有什么优势和特点May 16, 2022 pm 06:04 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于redis的一些优势和特点,Redis 是一个开源的使用ANSI C语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式存储数据库,下面一起来看一下,希望对大家有帮助。

实例详解Redis Cluster集群收缩主从节点实例详解Redis Cluster集群收缩主从节点Apr 21, 2022 pm 06:23 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis Cluster集群收缩主从节点的相关问题,包括了Cluster集群收缩概念、将6390主节点从集群中收缩、验证数据迁移过程是否导致数据异常等,希望对大家有帮助。

Redis实现排行榜及相同积分按时间排序功能的实现Redis实现排行榜及相同积分按时间排序功能的实现Aug 22, 2022 pm 05:51 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,希望对大家有帮助。

详细解析Redis中命令的原子性详细解析Redis中命令的原子性Jun 01, 2022 am 11:58 AM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于原子操作中命令原子性的相关问题,包括了处理并发的方案、编程模型、多IO线程以及单命令的相关内容,下面一起看一下,希望对大家有帮助。

一文搞懂redis的bitmap一文搞懂redis的bitmapApr 27, 2022 pm 07:48 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了bitmap问题,Redis 为我们提供了位图这一数据结构,位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已,希望对大家有帮助。

实例详解Redis实现排行榜及相同积分按时间排序功能的实现实例详解Redis实现排行榜及相同积分按时间排序功能的实现Aug 26, 2022 pm 02:09 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,下面一起来看一下,希望对大家有帮助。

redis error什么意思redis error什么意思Jun 17, 2019 am 11:07 AM

redis error就是redis数据库和其组合使用的部件出现错误,这个出现的错误有很多种,例如Redis被配置为保存数据库快照,但它不能持久化到硬盘,用来修改集合数据的命令不能用。

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン