Chaos是一个基于Linux平台, reactor模式的网络事件库, 目前仅支持TCP传输协议, 仅在x86_64下编译, 并遵循3-clause BSD开源协议. 在使用上, 可以说它很像boost asio, 可能是由于我对boost asio的接口设计很有爱吧, 而且对于boost asio在异步编程方面的思想, 我个人也比较认同, 但至今我也没有仔细阅读过boost asio的源码, 一是boost的模板化编程在可读性上让我比较折磨, 其二则是不想在对设计先入为主的情况下去开发chaos, 很多事情只有我们自己亲自去思考, 才能有所收获.

 
    进入主题, 关于chaos库源码和所有测试用例和应用服务, 都在https://github.com/lyjdamzwf/chaos下载
 
 
源码目录结构
 
chaos                                   - chaos库源码

async_method                        - 用于异步消息队列的实现, 是最小的task单位, 类似于boost::bind & boost:function
utility                                   - 常用工具类
thread                                  - 对pthread的封装
task_service                          - 核心模块, 包含了异步消息队列, 网络I/O管理, 以及超时事件,ask_service可以作为多线程异步编程强大的工具而不单单作为一个网络层的reactor模块(相当于boost asio的io_service)
log                                       - 日志组件
heart_beat                            - 基于task_service的通用型元素心跳管理.
network                                - 基于task_service, 对tcp server进行了封装, 底层I/O multiplexing使用epoll LT模式, 提供了常用的socket行为, 统一对连接进行管理, 并提供了用户空间的读写缓冲区, 可以使开发者快速地搭建一个tcp服务器
test                                     - 一些测试用例, 小到一个工具类的测试, 大到不同类型的服务器程序
 
 
简单的TCP Server
要建立一个tcp server, 使用chaos只要简单的三步:
 
1.首先我们要先定义一个连接事件回调, 当chaos发现任何连接状态的改变都会回调该函数

 
 
2. 连接策略类的定义, 该类告诉chaos对于tcp数据包如何处理

这里需要特别说明一点的是, 对于tcp字节流的处理, chaos底层有默认的机制, 当一个完整的数据包被读取之后, handle_packet就会被调用, 可以看到, 服务在收到完整的数据包之后, 发送了同样的内容给对端.

默认策略的实现就在test_server_echo_conn_t所继承的default_conn_strategy_t中, 该类对所有tcp字节流的处理流程是:

 
默认策略的包头成员:

如果你希望使用自己的tcp字节流解析策略, 那么可以自己继承chaos::network::connection_t进行实现, 在初始化服务的时候注入自己的策略即可, 具体方式是提供一个你继承自connection_t的类, 然后作为tcp_service_t的模板参数
 
 
3.初始化并启动服务

    chaos::network::tcp_service_t类的运行机制是固定一个线程做accept的工作, 而accept成功的连接会分派到各个work线程上进行I/O, work线程的数量可在start时指定.
    这样就完成了一个简单的tcp echo server的建立,  以上只是我截取的关键代码片段, 在chaos/test/echo_server目录中有完整的代码可供参考.

如何生成并应用chaos到自己的项目

chaos目前提供的链接方式是以静态库(.a)存在的, 你可以运行根目录下的build_all.sh脚本进行生成(需要安装automake软件), 你不需要再安装任何第三方库即可编译整个chaos, 当编译完成后会在根目录生成lib临时目录,里面即包含相应的chaos静态库, 之后可参照test目录下的用例的方式链接到自己的项目中.

 

网络库之外看chaos

之前我曾提到task_service不仅仅是作为一个网络库的Reactor核心, 它亦可作为日常开发当中多线程及异步编程的利器, 让你不用关心线程切换, 多线程消息投递等细节问题, 通过简单地将请求包装成一个异步方法, 投递到指定的task_service(线程池)中, 就能执行该任务, 在之后的系列文章中我会做详细分析.

Chaoslibevent, boost asio, ACE, ICE等知名库的不同之处

从开始写chaos时, 我的初衷可能就不是libevent, boost asio那样的通用库, 而是帮助使用者快速搭建一个简单易用的tcp服务, 基于reactor核心写的network模块也是出于这个目的而做的封装. 如果使用libevent或boost asio, 你依然要关心如何去接受一个连接, 去创建启动线程, 去驱动EventLoop, 考虑如何分配线程, 如何管理连接, 而如果使用ACE, ICE, 又会显得比较臃肿庞大, 另一个角度看, ICE是个网络服务解决方案, 而不是单纯的网络库, 而chaos就介于他们之间, 即保持着一定的轻量化, 也希望使用者能够足够易用快速开发, 当然, 这样也必然会失去一些灵活性, 但我个人觉得这对于绝大部分应用都无伤大雅.

性能

对于部分应用来讲, 虽然网络层不会成为整个服务的瓶颈所在, 但网络库的性能依然至关重要, 我个人认为在本机做吞吐量的测试是一个不错的途径, 而且不用考虑硬件网卡的限制, 我的方法是在同样的机器环境上, 根据不同的应用层缓冲区大小, 连接数, 单线程/多线程 这几个方面来评测.

具体流程是, 客户端启动N个线程并启动N个TCP连接向服务器发送数据, 服务器接收到完整的数据包之后马上回传相同内容给对端(如同上面的echo server), 一段时间后统计整个过程的吞吐量, 以下是我统计的相关数据:

测试环境信息

服务器型号: HP DL160

CPU: E5504

MEM:

OS: centOS 5.8

当然, 需要一提的是这份吞吐量测试报告和其他一些网络库的吞吐量测试没有太大的可对比性, 毕竟不同的硬件环境,不同的测试代码给结果带来的差距比我们想象当中的要大.

吞吐量的测试客户端可在test/throughput_client目录中找到完整的代码

服务器代码见echo_server

待续

之后我会根据个人时间继续推出一些系列的文章和大家分享, 继续讨论chaos的一些设计上遇到的问题, 同时库本身还存在很多问题, 我会继续完善下去.

更多信息请关注:

新浪微博         -   http://weibo.com/crazyprogramerlyj

ChinaUnix博客 -    http://blog.chinaunix.net/space.php?uid=14617649

转载于:https://www.cnblogs.com/zhiranok/archive/2012/07/04/chaos_1.html

发布一个开源的c++网络事件库【转载Zark@cppthinker.com】相关推荐

  1. 利用epoll写一个迷你的网络事件库

    epoll是linux下高性能的IO复用技术,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率.另一点原因就是获取 ...

  2. 教你一步步发布一个开源库到 JCenter

    本篇文章已授权微信公众号 dasu_Android(大苏)独家发布 今天想来分享下,如何一步步自己发布一个开源库到 JCenter 这方面的博客网上已经特别多了,所以本篇并不打算仅仅只是记录流程步骤而 ...

  3. android post请求添加公共参数_XHttp2 一个功能强悍的网络请求库

    XHttp2 一个功能强悍的网络请求库,使用RxJava2 + Retrofit2 + OKHttp组合进行封装.还不赶紧点击使用说明文档,体验一下吧! 项目地址 关于我 https://github ...

  4. 如何封装并发布一个属于自己的ui组件库

    以前就一直有个想法自己能不能封装一个类似于elementui一样的组件库,然后发布到npm上去,毕竟前端说白了,将组件v上去,然后进行数据交互.借助这次端午,终于有机会,尝试自己去封装发布组件库了 我 ...

  5. 发布一个 Linux 下的 C++ 多线程库

    发布一个我自己业余时间编写的 C++ 多线程库 for Linux,这个库只有不到 1000 行源代码,封装了 pthreads 的常用功能(互斥器.条件变量.线程),实现了简单的线程池,并仿照 ja ...

  6. 刚发布一个开源的UMD电子书构建工具

    刚发布一个UMD电子书构建工具([url]http://code.google.com/p/umd-builder/[/url]) Umd Builder是一个开源的UMD电子书构建.制作工具.UMD ...

  7. 介绍一个开源的SIP(VOIP)协议库PJSIP

    本文系转载,出处不可考. 假设你对SIP/VoIP技术感兴趣,哪希望你不要错过:),假设你对写出堪称优美的Code感兴趣 ,那么你也不可错过:) 这期间我想分析一下一个实际的协议栈的设计到实现的相关技 ...

  8. 介绍一个开源的高分辨率遥感影像处理库-OTB

    官方网址:http://www.orfeo-toolbox.org/otb/ 先粘贴一些官网的介绍链接过来,等有有较深入研究后翻译一些过来. OTB is a C++ library for high ...

  9. 移动端手势的七个事件库

    1:GMU:http://cloudajs.org/ui/brand/gmu GMU是基于zepto的mobile UI组件库,提供webapp.pad端简单易用的UI组件! http://gmu.b ...

最新文章

  1. ZooKeeper 基本介绍
  2. python处理xml中非法字符的一种思路
  3. dnf mysql数据库密码,CentOS7使用dnf安装mysql的方法
  4. SparkSql常用命令操作
  5. java日历记事本ppt_JAVA做的日历记事本
  6. Git之深入解析如何将项目迁移到Git
  7. shell脚本字符串截取的8种方法
  8. 6 计算机组成原理第五章 中央处理器 CPU功能和结构 指令执行过程
  9. OPPO Reno3系列旗舰官宣:骁龙765G+正反双曲面设计
  10. ubuntu上编译fortran_Ubuntu下安装Intel Fortran编译器(ifort)
  11. java.sql.date获取当前时间_关于JDBC中如何使用sql.Date获取当前时间以及对时间的操作和转换...
  12. 关于计算机动画制作的过程,关于计算机制作动画的过程
  13. Memory Limited Persistent Message Queue
  14. python 01列表异或_【快速跟水】图像隐写的python实现
  15. 我的世界服务器水流动配置文件,我的世界后台的水流动命令是什么
  16. 哪个品牌台灯护眼效果好?分享被央视315表扬的护眼灯
  17. 移动宽带套餐介绍_中国移动宽带最新套餐介绍
  18. 实战 —— 生存唯一随机数
  19. Android实现二维码扫描功能(四)-ZXing识别图片二维码,相册选图
  20. 参数化建模类毕业论文文献有哪些?

热门文章

  1. Finite Difference Frequency Domain(FDFD) 算法和C++实现
  2. c语言字符叠加,电梯楼层字符叠加器JA-1012C
  3. 【Demllie航天】宇宙飞船与火箭,着陆与回收
  4. AI艺术的背后:详解文本生成图像模型【基于 VQ-VAE】
  5. 迅睿cms免登陆新闻发布接口
  6. 详解Linux-I2C驱动(硬件原理\驱动分析\测试)
  7. latex转word python_分分钟甩Word几条街,Python编辑公式竟可以如此简单!
  8. Vicakte_应用程序商店审查指南
  9. codeforces-1395D Boboniu Chats with Du【前缀和】【枚举】
  10. 我读过的一些编程相关的书籍