水平触发(Level-Triggered,LT)
- 概念:当文件描述符处于可读或可写状态时,水平触发机制会持续发出通知,直到该状态发生变化。比如一个文件描述符有数据可读,那么只要数据没有被全部读完,内核就会不断地通知应用程序有数据可读。
- 特点
- 优点:容易理解和实现,应用程序可以在每次收到通知时按需处理一部分数据,不用担心遗漏事件。适用于需要按需处理数据的场景,如批量数据处理、文件传输等。
- 缺点:如果有大量不需要读写的就绪文件描述符,它们每次都会返回,会大大降低处理程序检索自己关心的就绪文件描述符的效率,可能产生大量不必要的通知。
- 应用场景:适合于基于阻塞I/O或者非阻塞I/O的应用,常用于对及时性要求不是极高,但需要确保数据能够完整处理的场景。
边缘触发(Edge-Triggered,ET)
- 概念:只在文件描述符的状态从不可读变为可读、或者从不可写变为可写等状态发生变化的瞬间发出一次通知。之后,即使文件描述符仍然处于可读或可写状态,内核也不会再发出通知,直到下一次状态再次发生变化。
- 特点
- 优点:可以减少不必要的上下文切换和事件通知频率,在处理大量并发连接时能显著提高效率,减少系统开销。
- 缺点:要求应用程序在收到通知后必须尽可能地处理完所有相关的I/O操作,增加了应用程序的复杂性,调试也相对困难。
- 应用场景:适合于高性能的异步非阻塞I/O应用,如高性能网络服务器,能更好地利用系统资源。
命名原因
这两个名字来源于数字电路中的电平触发和边沿触发概念。
- 水平触发:在数字电路中,电平触发是指只要信号达到或超过某个阈值,触发状态就会一直持续。在Linux的I/O模型中,水平触发与之类似,只要文件描述符的I/O状态满足可读或可写等条件,就会持续触发通知,就像电路中持续的高电平或低电平信号一样,所以被称为水平触发。
- 边缘触发:在数字电路里,边沿触发是指在信号的上升沿或下降沿才会触发事件。对应到Linux的I/O操作,边缘触发只在文件描述符的状态发生变化的瞬间,即从无就绪变为就绪的这个“边沿”时刻触发通知,如同电路中信号电平发生跳变的瞬间才起作用,因此被命名为边缘触发。