网络与服务器编程框架库 acl_3.0.18 发布

acl 3.0.18 版本 (项目主页:https://sourceforge.net/projects/acl/,技术文章主页:http://zsxxsz.iteye.com/)) 发布了,acl 是 one advanced C/C++ library 的简称,主linux

 

要包括网络通讯库以及服务器框架库等功能,支持 Linux/Windows/Solaris/FreeBsd/MacOS 平台;整个 acl 项目主要包含三个函数库:lib_acl(纯C开发的基础库,主要包含网络通git

 

信及服务器编程框架以及其它丰富的功能)、lib_protocol(包含 HTTP/PING/SMTP 通讯协议的C语言实现)、lib_acl_cpp(基于 lib_acl 及 lib_protocol 两个C库,提供了更为强大的github

 

编程接口及丰富的功能类);本次 acl 升级除了一些 bug 修复外,主要优化了 ACL 中的网络服务器框架、事件引擎以及线程池调度算法,同时增长了客户端链接分发器模块。算法

 

acl 包括如下丰富的经常使用函数库:数据库

一、常见网络应用库: SMTP 客户端库/PING 库/memcache 客户端库/handlersocket 客户端库/beanstalk 客户端库编程

二、HTTP 网络库:HTTP 客户端/服务端库,C++版 HttpServlet 类,HTTP COOKIE/HTTP SESSION 等json

三、邮件解析库:mime解析库/RFC2047/RFC2048/mime base64/mime qp/mime uucode 等性能优化

四、网络通讯库:阻塞/非阻塞网络 IO 库(其中 lib_acl_cpp 库经过嵌入 polarssl 而具有了 SSL 的能力)服务器

五、服务器框架:包括进程池模式、线程池模式、非阻塞模式、UDP通讯模式及触发器模式网络

六、事件引擎:支持 select、poll(for unix)、epoll(for linux)、kqueue(for bsd)、devpoll(for solaris)、iocp(for win32)、win32 窗口消息(for win32)事件引擎

七、通用链接池库:高效的链接池基础类库,支持丰富的功能

八、数据库客户端库:对原生的数据库客户端库进行了二次封装,使编程更为简易,功能更为丰富

九、xml/json 流式解析库:区别于网上其它已有的 xml/json 解析库,acl 中的 xml/json 解析库采用有限状态机方式解析数据,处理方式更为灵活

 

1、基础 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,应该在套接字关闭前先取得完成端口状态

 

2、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 存在内存泄露问题

 

3、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

相关文章
相关标签/搜索