C/C++网络与服务器编程框架库,acl_3.0.18 发布
acl 3.0.18 版本 (项目主页:https://sourceforge.net/projects/acl/,技术文章主页:http: //zsxxsz.iteye.com/)) 发布了,acl 是 one advanced C/C++ library 的简称,主要包括网络通信库以及服务器框架库等功能,支持 Linux/Windows/Solaris/FreeBsd/MacOS 平台;整个 acl 项目主要包含三个函数库:lib_acl(纯C开发的基础库,主要包含网络通信及服务器编程框架以及其它丰富的功能)、lib_protocol(包含 HTTP/PING/SMTP 通信协议的C语言实现)、lib_acl_cpp(基于 lib_acl 及 lib_protocol 两个C库,提供了更为强大的编程接口及丰富的功能类);本次 acl 升级除了一些 bug 修复外,主要优化了 ACL 中的网络服务器框架、事件引擎以及线程池调度算法,同时增加了客户端连接分发器模块。
acl 包括以下丰富的常用函数库:
1、常见网络应用库: SMTP 客户端库/PING 库/memcache 客户端库/handlersocket 客户端库/beanstalk 客户端库
2、HTTP 网络库:HTTP 客户端/服务端库,C++版 HttpServlet 类,HTTP COOKIE/HTTP SESSION 等
3、邮件解析库:mime解析库/RFC2047/RFC2048/mime base64/mime qp/mime uucode 等
4、网络通信库:阻塞/非阻塞网络 IO 库(其中 lib_acl_cpp 库通过嵌入 polarssl 而具备了 SSL 的能力)
5、服务器框架:包括进程池模式、线程池模式、非阻塞模式、UDP通信模式及触发器模式
6、事件引擎:支持 select、poll(for unix)、epoll(for linux)、kqueue(for bsd)、devpoll(for solaris)、iocp(for win32)、win32 窗口消息(for win32)事件引擎
7、通用连接池库:高效的连接池基础类库,支持丰富的功能
8、数据库客户端库:对原生的数据库客户端库进行了二次封装,使编程更为简易,功能更为丰富
9、xml/json 流式解析库:区别于网上其它已有的 xml/json 解析库,acl 中的 xml/json 解析库采用有限状态机方式解析数据,处理方式更为灵活
一、基础 C 库:lib_acl
.新特性:线程池中(acl_thread_pool.c)的子线程的等待时间间隔分成多个等待时间片
.新特性:服务器模板(acl_aio_server.c, acl_thread_server.c)支持向连接分发器报告状态,从而允许从连接派发器处接收客户端连接
.新特性:借鉴了 glib 库中的一些宏定义,针对 gcc 或 vc 编译器增加了一些编译属性开关(如过期 API 调用警告)
.性能优化:线程池调度算法优化(每一个线程一个独立的线程条件变量,从而可以有效地避免线程池事件通知时的惊群现象)
.性能优化:事件引擎支持检测全部套接字的时间间隔设置,当并发连接较大时,可以有效地提升事件检测的性能
.性能优化:禁用事件引擎中的自旋锁,降低 CPU 损耗
.问题修复:acl_vstream_net.c 中 acl_vstream_accept_ex 接收外来连接时,判断监听描述符的类型方式有误
.问题修复:acl_getpeername 函数当客户端连接的是域套接字时,给出的地址不对
.问题修复:acl_master 服务器模块在 reload 配置文件时有可能会导致产生 core 文件
.问题修复:events_epoll_thr.c 在函数 event_disable_readwrite 中调用 epoll_ctl 删除描述字时,也必须保证第四个参数(struct epoll_event*) 非空,否则在低版
本 LINUX 下会有问题
.问题修复:events_iocp.c 关闭未决状态的完成端口在 WIN XP 下存在 BUG,应该在套接字关闭前先取得完成端口状态
二、lib_acl_cpp 库
.新特性:connect_manager 连接池集群管理器增加了后台检测功能,新增加的类 connect_monitor 为一个非阻塞线程,会在后台定期检测连接池集群中的所有服务器的端口是否存活
.新特性:借鉴了 glib 库中的一些宏定义,针对 gcc 或 vc 编译器增加了一些编译属性开关(如过期 API 调用警告)
.新特性:db_pool 类增加了 peek_open 方法,可以在获取数据库对象时直接打开数据库连接
.新特性:将 master_threads 替换为 master_threads2
.问题修复:md5.cpp 其中在 WIN32 下使用 sprintf_s 函数时,传入的长度参数应为 3,否则 VC 会报错
.问题修复:event_timer.cpp, 在 32 位机下会因 64 位整数转 32 位整数而导致 32 位整数溢出问题
.问题修复:master_threads/master_threads2 存在内存泄露问题
三、app/master_dispatch: 增加了客户端连接分发器模块,通过该模块,可以非常均匀地将客户端连接分发给使用 acl 服务器框架的应用子进程
参考链接:
技术博客:http://zsxxsz.iteye.com/
download:http://sourceforge.net/projects/acl/
svn:svn checkout svn://svn.code.sf.net/p/acl/code/trunk acl-code
github:https://github.com/zhengshuxin/acl