ACE接受器-连接器模式

上传人:飞*** 文档编号:32957838 上传时间:2018-02-13 格式:DOC 页数:8 大小:122.50KB
返回 下载 相关 举报
ACE接受器-连接器模式_第1页
第1页 / 共8页
ACE接受器-连接器模式_第2页
第2页 / 共8页
ACE接受器-连接器模式_第3页
第3页 / 共8页
ACE接受器-连接器模式_第4页
第4页 / 共8页
ACE接受器-连接器模式_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《ACE接受器-连接器模式》由会员分享,可在线阅读,更多相关《ACE接受器-连接器模式(8页珍藏版)》请在金锄头文库上搜索。

1、ACE 接受器连接器模式接受器连接器设计模式(Acceptor-Connector)使分布式系统中的连接建立及服务初始化与一旦服务初始化后所执行的处理去耦合。这样的去耦合通过三种组件来完成:acceptor、 connector 和 servicehandler(服务处理器)。1. 连接器主动地建立到远地接受器组件的连接,并初始化服务处理器来处理在连接上交换的数据。2. 接受器被动地等待来自远地连接器的连接请求,在这样的请求到达时建立连接,并初始化服务处理器来处理在连接上交换的数据。3. 初始化的服务处理器执行应用特有的处理,并通过连接器和接受器组件建立的连接来进行通信。结构1. 服务处理器(

2、Service Handler):Service Handler 实现应用服务,通常扮演客户角色、服务器角色,或同时扮演这两种角色。它提供挂钩方法,由 Acceptor 或 Connector 调用,以在连接建立时启用应用服务。此外,Service Handler 还提供数据模式传输端点,其中封装了一个 I/O 句柄。一旦连接和初始化后,该端点被 Service Handler 用于与和其相连的对端交换数据。2. 接受器(Acceptor):Acceptor 是一个工厂,实现用于被动地建立连接并初始化与其相关联的 Service Handler 的策略。此外,Acceptor 包含有被动模式的

3、传输端点工厂,它创建新的数据模式端点,由 Service Handler 用于在相连的对端间传输数据。通过将传输端点工厂绑定到网络地址,比如 Acceptor 在其上侦听的 TCP 端口号,Acceptor 的 open 方法对该工厂进行初始化。 一旦初始化后,被动模式的传输端点工厂侦听来自对端的连接请求。当连接请求到达时,Acceptor 创建 Service Handler,并使用它的传输端点工厂来将新连接接受进 Service Handler 中。3. 连接器(Connector):Connector 是一个工厂,实现用于主动地建立连接并初始化与其相关联的 Service Handler

4、 的策略。它提供方法,由其发起到远地 Acceptor 的连接。同样地,它还提供另一个方法,完成对 Service Handler 的启用;该处理器的连接是被同步或异步地发起的。Connector 使用两个分开的方法来透 明地支持异步连接建立。4. 分派器(Dispatcher):为 Acceptor,Dispatcher 将在一或多个传输端点上接收到的连接请求多路分离给适当的 Acceptor。Dispatcher 允许多个 Acceptor 向其登记,以侦听同时在不同端口上从不同对端而来的连接。 为 Connector,Dispatcher 处理异步发起的连接的完成。在这种情况下,当异步连

5、接被建立时,Dispatcher 回调 Connector。Dispatcher 允许多个 Service Handler 通过一个 Connector 来异步地发起和完成它们 的连接。注意对于同步连接建立,Dispatcher 并不是必需的,因为发起连接的线程控制也完成服务服务处 理器的启用。Dispatcher 通常使用事件多路分离模式来实现,这些模式由反应器(Reactor )或前摄器(Proactor ) 来提供,它们分别处理同步和异步的多路分离。同样地,Dispatcher 也可以使用主动对象(Active Obj ect)模式5来实现为单独的线程或进程。协作Acceptor 组件协

6、作Acceptor 和 Service Handler 之间的协作。这些协作被划分为三个阶段:1. 端点初始化阶段:为被动地初始化连接,应用调用 Acceptor 的 open 方法。该方法创建被动模式的传 输端点,将其绑定到网络地址,例如,本地主机的 IP 地址和 TCP 端口号,并随后侦听来自对端 Connector 的连接请求。其次, open 方法将 Acceptor 对象登记到 Dispatcher,以使分派器能够在连接事件 到达时回调 Acceptor。最后,应用发起 Dispatcher 的事件循环,等待连接请求从对端 Connector 到来。2. 服务初始化阶段:当连接请求到

7、达时,Dispatcher 回调 Acceptor 的 accept 方法。该方法装配以下活动 所必需的资源:1. 创建新的 Service Handler,2. 使用它的被动模式传输端点工厂来将连接接受进 该处理器的数据模式传输端点中,3. 通过调用 Service Handler 的 open 挂钩将其启用。Servic e Handler 的 open 挂钩可以执行服务特有的初始化,比如分配锁、派生线程、打开日志文件,和/或将 该 Service Handler 登记到 Dispatcher。3. 服务处理阶段:在连接被动地建立和 Service Handler 被初始化后,服务处理阶段

8、开始了。在此阶段, 应用级通信协议,比如 HTTP 或 IIOP,被用于在本地 Service Handler 和与其相连的远地 Peer 之间、 经由前者的 peer_stream_端点交换数据。当交换完成,可关闭连接和 Service Handler,并释放资源。Connector 组件协作Connector 组件可以使用同步和异步两种方式来初始化它的 Service Handle,这里仅介绍一下同步时的协作情况。同步的 Connector 情况中的参与者之间的协作可被划分为以下三个阶段:1. 连接发起阶段:为在 Service Handler 和它的远地 Peer 之间发起连接,应用调用

9、 Connector 的 connect 方法。该方法阻塞调用线程的线程控制、直到连接同步完成,以主动地建立连接。2. 服务初始化阶段:在连接完成后,Connector 的 connect 方法调用 complete 方法来启用 Service Handl er。complete 方法通过调用 Service_Handler 的 open 挂钩方法来完成启用;open 方法执行服务特有的 初始化。3. 服务处理阶段:此阶段与 Service Handler 被 Acceptor 创建后所执行的服务处理阶段相类似。特别地, 一旦 Service Handler 被启用,它使用与和其相连接的远地

10、Service Handler 交换的数据来执行应用特 有的服务处理。实现运行一般步骤:1. 创建 Service Handler;2. 被动地或主动地将 Service Handler 连接到它们的远地对端;以及3. 一旦连接,启用 Service Handler。主要角色:Service Handler(服务处理器)、Acceptor 和 Connector。服务处理器:该抽象类继承自 Event_Handler,并为客户、服务器或同时扮演两种角色的组件所提供 的服务处理提供通用接口。应用必须通过继承来定制此类,以执行特定类型的服务。Service Handler 接口如下所示:Cpp 代

11、码 1. template 2. class Service_Handler : public Event_Handler 3. 4. public: 5. /连接成功后的初始化入口函数 (子类定义). 6. virtual int open (void) = 0; 7. /返回通信流的引用 8. PEER_STREAM &peer (void) 9. 10. return peer_stream_; 11. 12. ; 一旦 Acceptor 或 Connector 建立了连接,它们调用 Service Handler 的 open 挂钩。该纯虚方法必须被 Concrete Service

12、Handler 子类定义;后者执行服务特有的初始化和后续处理。连接器:该抽象类实现主动连接建立和初始化 Service Handler 的通用策略。它的接口如下所示:Cpp 代码 1. template 2. class Connector : public Event_Handler 3. 4. public: 5. enum Connect_Mode 6. 7. SYNC, /以同步方式连接 8. ASYNC /以异步方式连接 9. ; 10. / 主动连接并激活服务处理器 11. int connect (SERVICE_HANDLER *sh, 12. const PEER_CONNE

13、CTOR:PEER_ADDR &addr, 13. Connect_Mode mode); 14. protected: 15. /定义连接激活策略 16. virtual int connect_service_handler(SERVICE_HANDLER *sh, 17. const PEER_CONNECTOR:PEER_ADDR &addr, 18. Connect_Mode mode); 19. / Defines the handlers concurrency strategy. 20. virtual int activate_service_handler(SERVICE_

14、HANDLER *sh); 21. / 当以异步方式连接完成时激活服务处理器 22. virtual int complete (HANDLE handle); 23. private: 24. / IPC mechanism that establishes 25. / connections actively. 26. PEER_CONNECTOR connector_; 27. ; Conncetor 通过特定类型的 PEER CONNECTOR 和 SERVICE HANDLER 被参数化。PEER CONNECTO R 提供的传输机制被 Connector 用于主动地建立连接,或是同

15、步地、或是异步地。SERVICE HANDLER 提供的服务对与相连的对端交换的数据进行处理。C+参数化类型被用于使(1)连接建立策略与(2)服务处理器类型、网络编程接口和传输层连接协议去耦合。参数化类型是有助于提高可移植性的实现决策。例如,它们允许整体地替换 Connector 所用的 IPC 机 制。这使得 Connector 的连接建立代码可在含有不同网络编程接口(例如,有 socket,但没有 TLI;反之 亦然)的平台间进行移植。Service Handler 的 open 挂钩在连接成功建立时被调用。接受器(Acceptor):该抽象类为被动连接建立和初始化 Service Handler 实现通用的策略。Acceptor 的接 口如下所示:Cpp 代码 1. template 3. class Acceptor : public Event_Handler 4. 5. public: 6. / Initialize local_addr transport endpoint factory 7. / and register with Initiation_Dispatcher S

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号