前摄器模式
1.前摄器的原理
前摄器模式是充分使用了操作系统的支持异步I/O的特性,使用异步来代替多线程并发,因为多线程并发会带来很多性能的开销(创建、切换、同步等),而异步像更加底层的操作系统操作,性能是相对较高(为什么?待补充)
2.前摄器的优点
“与传统的反应式或同步式I/O模型不同,前摄式模型允许每个应用线程同时发起多个操作。这一设计允许单线程化应用并发地执行多个I/O操作,并且不会带来与传统的多线程化机制相关联的开销或设计复杂性”
“使用前摄器模式的主要优点是可以启动多个并发操作,并可并行运行,而不要求应用必须拥有多个线程。操作被应用异步地启动,它们在OS的I/O子系统中运行直到完成。发起操作的线程现在可以服务另外的请求了。
Completion Dispatcher可以是单线程的。当HTTP请求到达时,单个Completion Dispatcher线程解析请求,读取文件,并发送响应给客户。因为响应是被异步发送的,多个响应就有可能同时被发送。而且,同步的文件读取可以被异步的文件读取取代,以进一步增加并发的潜力。如果文件读取是被异步完成的,HTTP Handler所执行的唯一的同步操作就只剩下了HTTP协议请求解析。
前摄式模型的主要缺点是编程逻辑至少和反应式模型一样复杂。而且,前摄器模式可能会难以调试,因为异步操作常常有着不可预测和不可重复的执行序列,这就使分析和调试复杂化了。”
3.类介绍:
ACE_Service_Handler
/**
* @class ACE_Service_Handler
*
* @brief This base class defines the interface for the
* ACE_Asynch_Acceptor to call into when new connection are
* accepted.
*
* Subclasses of this class will fill in appropriate methods to
* define application specific behavior.
*/
这个是创建服务器 处理器的必须的目标类。此类中的open()挂钩方法会在新连接建立时被调用。
ACE_Asynch_Read_Stream
/**
* @class ACE_Asynch_Read_Stream
*
* @brief This class is a factory for starting off asynchronous reads
* on a stream. This class forwards all methods to its
* implementation class.
*
* Once {open} is c