复述,多路复用原理是什么以及常见问题有哪些

介绍

这篇文章给大家分享的是有关复述,多路复用原理是什么以及常见问题有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。

<强>一、复述的单线程理解

复述,客户端对服务端的每次调用都经历了发送命令,执行命令,返回结果三个过程。其中执行命令阶段,由于复述是单线程来处理命令的,所有到达服务端的命令都不会立刻执行,所有的命令都会进入一个队列中,然后逐个执行,并且多个客户端发送的命令的执行顺序是不确定的,但是可以确定的是不会有两条命令被同时执行,不会产生并发问题,这就是复述的单线程基本模型。

复述,服务器通过插座(套接字)与客户端或其他复述,服务器进行连接,而文件事件就是服务器对套接字操作的抽象。服务器与客户端或其他服务器的通信会产生相应的文件事件,而服务器通过监听并处理这些事件来完成一系列网络通信操作。

复述,基于反应堆模式开发了自己的网络事件处理器——文件事件处理器,文件事件处理器使用I/O多路复用程序来同时监听多个插座(I/O多路复用技术下面有介绍),并根据套接字目前执行的任务来为套接字关联不同的事件处理器。当被监听的套准备好执行连接应答,读取,写入,关闭等操作时,与操作相对应的文件事件就会产生,这时文件事件处理器就会调用套接字之前已关联好的事件处理器来处理这些事件。

文件事件处理器的构成:

复述,多路复用原理是什么以及常见问题有哪些“> <p>注意:其中I/O多路复用程序通过队列向文件事件分派器传送套接字</p> <p> <强>二、I/O多路复用技术</强> </p> <p>关于I/O多路复用(又被称为“事件驱动”),首先要理解的是,操作系统为你提供了一个功能,当你的某个插座可读或者可写的时候,它可以给你一个通知。这样当配合非阻塞的套接字使用时,只有当系统通知我哪个描述符可读了,我才去执行读操作,可以保证每次读都能读到有效数据而不做纯返回1和EAGAIN的无用功,写操作类似。</p> <p>操作系统的这个功能是通过选择/调查/epoll/kqueue之类的系统调用函数来实现,这些函数都可以同时监视多个描述符的读写就绪状况,这样,多个描述符的I/O操作都能在一个线程内并发交替地顺序完成,这就叫I/O多路复用,这里的“多路”指的是多个网络连接,“复用”指的是复用同一个复述,处理线程。(正如上图所示)</p> <p>采用多路I/O复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络I/O的时间消耗),且复述,在内存中操作数据的速度非常快,也就是说内存内的操作不会成为影响复述性能的瓶颈,所有复述,具有很高的吞吐量。</p> <p> <强>三,常见疑问解答</强> </p> <p> <强> 1,复述的单线程为什么这么快? </强> </p> <p> 1。完全基于内存,绝大部分请求是纯粹的内存操作,非常快速。数据存在内存中,类似于HashMap, HashMap的优势就是查找和操作的时间复杂度都是O (1), </p> <p> 2。数据结构简单,对数据操作也简单,复述中的数据结构是专门进行设计的;</p> <p> 3。采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗CPU、不用去考虑各种锁的问题,不存在加锁释放锁操作,没有因为可能出现死锁而导致的性能消耗;</p> <p> 4。使用多路I/O复用模型,非阻塞I/O; </p> <p> 5。复述,直接自己构建了VM机制,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求;</p> <p> <强> 2,为什么不采用多进程或多线程处理? </强> </p> <p> 1。多线程处理可能涉及到锁</p> <p> 2。多线程处理会涉及到线程切换而消耗CPU </p> <p> <强> 3,单线程处理的缺点吗? </强> </p> <p> 1。耗时的命令会导致并发的下降,不只是读并发,写并发也会下降</p> <p> 2。无法发挥多核CPU性能,不过可以通过在单机开多个复述,实例来完善</p> <p> <强> 4,复述,不存在线程安全问题? </强> </p> <p>复述,采用了线程封闭的方式,把任务封闭在一个线程,自然避免了线程安全问题,不过对于需要依赖多个复述,操作(即:多个复述,操作命令)的复合操作来说,依然需要锁,而且有可能是分布式锁。</p> <p class=感谢各位的阅读!关于复述,多路复用原理是什么以及常见问题有哪些就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!

复述,多路复用原理是什么以及常见问题有哪些