zoukankan      html  css  js  c++  java
  • 知识框架

    1、ACE并发编程:线程与同步

    • 线程与进程之区别;
    • 用户线程与内核线程;
    • 不同操作系统中的线程模型;
    • ACE线程管理:Thread_Manager;
    • ACE线程同步:ACE_Guard、ACE_Thread_Mutex等;
    • ACE Task框架:Message_Block、Message_Queue、ACE_Task。

    2、ACE Reactor框架

    ACE Reactor框架简化事件驱动程序的开发,而事件驱动是很多网络化应用的基本特征,这些应用常见的事件源包括I/O事件、Posix信号或 Windows句柄激发以及定时器到期等。

    • 关于ACE Reactor框架;
    • 关于事件多路分离和分派 (Event demultiplexing and dispatching );
    • Linux下 I/O事件多路分离机制:select、epoll;
    • 事件处理器 ACE_Event_Handler:
    • I/O事件(输入、输出)、信号、超时事件、异常事件的捕获和处理;
    • ACE_Timer_Queue和ACE_Time_Value:
    • 定时器的应用;
    • ACE_Reactor:ACE的反应器为ACE Reactor框架的核心,负责事件的检测、多路分离和事件处理器的分派;
    • 例程:基于ACE Reactor框架实现一个多人聊天室。

    3、ACE Acceptor-Connector框架

    ACE Acceptor-Connector框架实现了Acceptor-Connector模式,这种模式通过解除:1,网络化应用中相互协作的对等服务的连接和初始化所需的活动、2,以及它们一旦连接和初始化后所执行的处理的耦合,增强了软件复用和可扩展性。

    • 集成了Message_Queue的ACE_Event_handler:ACE_Svc_Handler;
    • 接受器:ACE_Acceptor;
    • 连接器:ACE_Connector;
    • 例程:基于Acceptor-Connector框架实现一个转发服务器。

    4、ACE Proactor框架

    Proactor框架引入异步I/O机制,既保留了Reactor框架的事件多路分离,避免多线程的开销,同时还缓和了反应式的同步I/O的瓶颈效应。

    • 关于Proactor模式和Proactor框架;
    • 关于异步I/O;
    • 异步I/O工厂类:
    • ACE_Asynch_Read_Stream和ACE_Asynch_Write_stream;
    • ACE_Handler;
    • 前摄式Acceptor-Connector;
    • 前摄器:ACE_Proactor;
    • 例程:基于Proactor框架重新实现多人聊天室。

    5、ACE实用工具

    • ACE日志实用工具:ACE_Log_Msg;
    • 读写配置文件:ACE_Configuration_Heap;
    • Singleton模式 (单例模式) 的ACE实现:ACE_Singleton类模板。

    6、高性能网络编程讨论

    • 考究高性能网络编程中应该遵循的原则,讨论并发、同步、事件多路分离等机制的适用场合。
    • 网络应用的瓶颈在何处?
    • 事件多路分离 vs 一连接一线程 (Event demultiplexing vs One thread per connection);
    • 同步I/O vs 异步I/O (Synchronous I/O vs Asynchronous I/O);
    • 如何适当地使用多线程?
    • 什么时候需要多个 事件多路分离线程?

    7、应用层协议定义与实现

    • 为什么要自定义应用层协议?
    • 定义应用层协议 (以XMMEP协议为例);
    • 用C++实现自定义的协议 (以XMMEP协议为例)。
    • 注:XMMEP为X-Messenger Message Exchanging Protocol。
  • 相关阅读:
    服务器扫描工具
    Address already in use: AH00072: make_sock: could not bind to address 0.0.0.0:443
    [warn] _default_ VirtualHost overlap on port 443, the first has precedence
    Apache环境下配置多个站点的SSL证书
    Linux漏洞扫描工具
    详细解读html中的Map,area标签
    Linux操作系统加固
    MySQL服务安全加固
    redis cluster管理工具redis-trib.rb详解
    Java中使用Jedis操作Redis
  • 原文地址:https://www.cnblogs.com/sevenyuan/p/1869762.html
Copyright © 2011-2022 走看看