跨平台网络通信与服务框架-acl
2014-07-05 19:52:00 阿炯

本站赞助商链接,请多关照。 acl 框架库是一个 C 库,主要包含:服务器开发框架、同步/异步网络通讯、常用数据结构、进程池/线程池、流式 xml/json 解析器、http/ping 应用协议等内容。采用GPLv2协议授权。


acl is one advanced C lib for unix and windows.

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 包括以下丰富的常用函数库:
1、服务器框架:包括进程池模式、线程池模式、非阻塞模式、UDP通信模式、触发器模式以及协程模式
2、网络通信库:阻塞/非阻塞网络 IO 库(其中 lib_acl_cpp 库通过嵌入 polarssl 而具备了 SSL 通信能力)
3、HTTP 网络库:HTTP 客户端/服务端库,HTTP 服务端支持 HttpServlet 接口访问方式;支持 HTTP cookies/session;HTTP 客户端支持连接池及连接池集群
4、redis 客户端库:实现了 redis 客户端命令中 12 个大类中的总共 150 多个命令,支持连接池及集群连接池方式
5、常见网络应用库: SMTP 客户端库/PING 库/DNS 解析库/memcache 客户端库/handler socket 客户端库/beanstalk 客户端库/disque 客户端库
6、邮件解析库:mime解析库/RFC2047/RFC2048/mime base64/mime qp/mime uucode 等
7、事件引擎:支持 select、poll(for unix)、epoll(for linux)、kqueue(for bsd)、devpoll(for solaris)、iocp(for win32)、win32 窗口消息(for win32)事件引擎
8、通用连接池库:高效的连接池基础类库,支持丰富的功能
9、数据库客户端库:对原生的数据库客户端库进行了二次封装,使编程更为简易,功能更为丰富,支持连接池及连接池集群管理功能
10、xml/json 流式解析库:区别于网上其它已有的 xml/json 解析库,acl 中的 xml/json 解析库采用有限状态机方式解析数据,处理方式更为灵活
11、网络协程库:该库将阻塞 IO 模式在底层通过上下文切换和事件触发方式转变为非阻塞模式,从而方便程序员快速编写高并发、高性能的网络服务

示例:
1、lib_acl/samples: 该目录下有大量的基于 lib_acl C 库的示例
2、lib_protocol/samples: 该目录下有大量的基于 lib_protocol C 库的示例
3、lib_acl_cpp/samples: 该目录下有大量的基于 lib_acl_cpp C++ 库的示例
4、lib_fiber/samples:该目录下有大量的基于协程的网络客户端/服务端示例

应用:
1、app/redis_tools: 该目录下为 redis 集群管理、监控及智能创建工具
2、app/wizard:用来自动生成 acl 服务器框架的向导程序
3、app/master_dispatch:用于管理和分发客户端连接的服务程序
4、app/gid:用来产生全局唯一整型 ID 的服务程序及客户端库
5、app/wizard_demo:为一些服务器测试程序


最新版本:3.0
一、基础 C 库:lib_acl
.新特性:acl_scan_dir.c 增加了一些功能接口
.新特性:服务器框架 acl_master 支持非 root 用户身份运行
.性能优化:线程池库(acl_pthread_pool.c), worker_wait() 函数将空闲线程添加至线程池和从线程池中移除的操作放在 pthread_cond_timedwait 等待循环的外面,这样既可以减少添加/移除操作的次数,同时又可以使等待任务超时的线程迟早地退出
.删除:去掉了 acl_ioctl_app_main.c/acl_aio_app_main.c,将 acl_aio_app_main.c 功能分别合并至 acl_aio_server.c 中;将 acl_ioctl_server.c 的接口申明为过期,建议用户使用 acl_threads_server.c 中的功能接口
.问题修复:acl_vstream.c 中函数 acl_vstream_ftell 问题修复
.问题修复:acl_aqueue.c 异步线程消息队列支持无限等待方式

二、lib_protocol 库
.问题修复:http_hdr_req.c 中函数 http_hdr_req_cookies_parse 解析处理 cookie 时存在内存冲突
 
三、lib_acl_cpp 库
.新特性:文件类 fstream(fstream.cpp)增加了 ftell 方法,用来表示当前文件指针位置
.新特性:连接类 connect_client(connect_client.cpp)增加了设置/获取连接池对象的方法
.新特性:字符串类 string(string.cpp)增加了多个功能接口,方便对字符串的操作
.新特性:增加了目录扫描类 scan_dir(scan_dir.cpp),可以非常方便地对目录进行扫描等操作
.新特性:连接池管理类 connect_manager(connect_manager.cpp)增加了连接池故障自动恢复功能
.问题修复:异步处理服务器类 master_aio(master_aio.cpp)在析构函数中不应调用异步处理函数,否则会引起内存冲突
.问题修复:http 处理类 http_client(http_client.cpp) 构造函数中未对缓冲区 buf_ 初始化,当调用 reset 方法会造成内存冲突

最新版本:3.2
本次 acl 升级的最主要内容为:增加了类似于 golang 中的网络协程库,该库使 C/C++ 程序员可以以顺序编程的思维方式快速地编写出高并发、高性能的网络服务器程序,该网络协程库参考了 golang 作者 Russ Cox 早年发布的 libtask 设计原型,同时还参考了 libmill/seatar/coroutines/libgo/libco/st 等大量有关协程的库,在此一并表示感谢,同时还需感谢 niukey@qq.com 对于协程的贡献;此外,lib_acl/lib_acl_cpp 也进行了功能改进和问题修复。


项目主页:http://sourceforge.net/projects/acl/