Netty学习第三章 Linux网络编程使用的I/O模型

一、同步阻塞IO:blocking IO(BIO)

  

 

 

 1.过程分析:

  当进程进行系统调用时,内核就会去准备数据,当数据准备好后就复制数据到内核缓冲器,复制完成后将数据拷贝到用户进程内存,整个过程都是阻塞的。

 2.特点:

  优点:能及时响应数据

  缺点:因为整个过程都是阻塞的,所以高并发下性能非常差

二、同步非阻塞IO:nonblocking IO(NIO)

  

1.过程分析:

  当进程调用系统时,会立即返回error,当用户知道返回的是error后就知道数据没有准备好,此时进程进行等待,这一个过程是非阻塞的,因此可以有多个调用请求。当请求来到时,内核会去准备数据,就和BIO的模式一样,当数据准备好后,复制给用户进程内存,这一个过程是阻塞的,但是用户进程会一直去轮询判断数据是否已经准备好了。

2.特点:

  优点:能够在数据处理好之前去做其他的事情

  缺点:性能还是很差,第一需要不断去判断数据是否准备好了;第二在拷贝数据这个过程中,进程依旧是阻塞的;第三因为是轮询去找数据,所以数据会有延迟

 

三、IO多路复用

  

1.定义:

  所谓的IO多路复用指的就是一个或多个线程处理多个TCP连接。

2.网络模型:

  IO多路复用的网络模型有三种:

  ①select模型:

  调用select函数时会阻塞住进程,等有数据可读、可写、出异常或者超时就会返回。select函数正常返回后,通过遍历fdset整个数组才能发现那些句柄发生了事件,来找到就绪的fd进行相应的IO操作。

  优点:所有平台都能够使用这种模型。

  缺点:

  ⑴ select函数采用轮询的方式扫描文件,如果fd多的话,性能就会很差。

  ⑵ 每次调用select函数,需要把fd集合从用户拷贝到内核中

  ⑶ 最大缺陷是单个进程打开的fd有限制的(1G的内存大概有10万个句柄)

  ②poll模型:

  这个模型和select模型一样,最大的区别就是poll没有最大文件描述符(fd)的限制

  ③epoll模型

  这个模型是在Linux2.6内核中正式加入的:对比select模型,epoll没有描述符限制,用户拷贝到内核的数据只需使用一次事件通知,通过epoll_ctl函数注册fd,一旦fd就绪,内核就会采用callback的回调机制来激活对应的fd。

  我们主要了解下它的工作函数:

  epoll_create:这个函数是用来创建一个epoll句柄,创建完成后epoll就会占用一个fd,这个函数返回的是一个epoll对象

  epoll_ctl:在epoll对象里添加删除对应的fd,并绑定一个callback函数

  epoll_wait:判断并成对应的IO操作

  epoll模型的特点:

  ⑴ 没有fd限制

  ⑵ 效率高,因为使用的是回调通知机制,不会随着fd的增加而降低性能

  ⑶ 用户和内核采用同一块内存实现回调

四、信号驱动

 

 

1.过程分析:

  这种模型与NIO类似,在第一个阶段进程发起请求时两个模型都是一样的,是非阻塞的,区别在于第二阶段:在信号驱动模型中,当内核准备好数据后会自动通知用户进程,进程收到通知后会自动去内核拷贝数据。

五、异步IO:asynchronous  IO(AIO)

  

 

 

1.过程分析:

  用户进程在系统调用后,就能够去继续做其他的事情,数据的第一、第二阶段都不是阻塞的,当数据准备好后。内核会自动通知用户来拷贝数据。

2.特点:

  读写操作都交给了内存来处理,用户只需要等待通知来获取就行。

posted @ 2019-11-17 20:14  想去天空的猫  阅读(454)  评论(0编辑  收藏  举报