acl 3.1.0 版本发布了,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、整个工程可以使用 clang/clang++ 编译通过;2、在 lib_acl_cpp 库中提供了 redis 客户端命令协议的完整实现,共 12 个大类,150 多个函数。除此之外,还包含一些小的功能改进与完善,以及一些 BUG 的修复。
acl 包括以下丰富的常用函数库:
1、常见网络应用库: SMTP 客户端库/PING 库/memcache 客户端库/handlersocket 客户端库/beanstalk 客户端库/redis 客户端库
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
.新特性:win32 iocp 模式下可以支撑更多的连接数,在 acl_events.c 中的函数(acl_event_new_kernel)中,将默认值设为 50000,使用者可以根据自己需要修改成更大的值
.新特性:增加了 acl_is_blocking() 函数用于判断套接字是阻塞模式还是非阻塞模式
.新特性:acl_vstring.c/vstring_extend 在内存自动增加时,原来采用了内存翻倍增长的方式,当原始内存比较大时容易造成很大内存浪费,现采用了 redis-server 中的策略,在一定范围内(1MB)增长时按翻倍增长方式,超过此范围则以 1MB 为单位进行递增
.问题修复:win32 iocp 模块(events_iocp.c)的函数 stream_on_close 中,应该增加 fdp->event_read 是否为空指针的判断
.问题修复:acl_dbuf_pool.c 在分配内存时存在因整数值溢出而导致的内存非法访问
.编译:整个项目可以使用 clang 编译器编译通过
二、lib_protocol 库
.新特性:在解析 HTTP 请求头的函数 http_hdr_req_line_parse 中,取消了 HTTP 请求方法的限制,从而允许应用可以扩展自己的 HTTP 请求方法
.编译:整个项目可以使用 clang 编译器编译通过
三、lib_acl_cpp 库
.新特性:HttpServlet 类简化了 doRun 参数
.新特性:增加了 dbuf_pool 内存分配类,该类适合于频繁分配大小不一的小内存的情况
.新特性:socket_stream 类增加了 get_tcp_non_blocking 方法用于判断当前套接字是否是非阻塞模式(目前仅支持 UNIX 平台)
.新特性:实现了所有的 redis 客户端协议,总共有 12 个大类,150多个客户端命令,同时支持连接池及连接池集群功能;支持的 12 个大类有:redis_hash/redis_string/redis_hyperloglog/redis_key/redis_list/redis_pubsub/redis_script/redis_server/redis_set/redis_zset/redis_transaction/redis_connection,另外还提供了连接池类 redis_pool 及连接池集群功能类 redis_manager
.新特性:http_header.cpp 中的 set_method 增加了 HEAD/OPTION 请求方法
.新特性:http_client.cpp 增加了 sprint_header 方法,可以将 HTTP 响应头输出至缓冲区内,以便于应用进行调试
.问题修复:db_mysql.cpp 在 WIN32 下使用 mysql 库采用了动态加载的方式,在函数指针前应增加 STDCALL 宏定义
.示例:增加了以下测试 redis 客户端命令的示例:
1、redis_connection:测试 redis 连接类
2、redis_hash:测试 redis 哈希表类
3、redis_hyperloglog:测试 redis hyperloglog 类
4、redis_key:测试 redis 健操作类
5、redis_list:测试 redis 键操作类
6、redis_pubsub:测试 redis 发布/订阅类
7、redis_server:测试 redis 服务管理类
8、redis_set:测试 redis 集合类
9、redis_string:测试 redis 字符串操作类
10、redis_trans:测试 redis 事务类
11、redis_zset:测试 redis 有序集合类
12、redis_zset_pool:使用 redis 有序集合类将大数据块拆分成小数据块,支持连接池方式
13、redis_pool:测试 redis 连接池操作类
acl 包括以下丰富的常用函数库:
1、常见网络应用库: SMTP 客户端库/PING 库/memcache 客户端库/handlersocket 客户端库/beanstalk 客户端库/redis 客户端库
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
.新特性:win32 iocp 模式下可以支撑更多的连接数,在 acl_events.c 中的函数(acl_event_new_kernel)中,将默认值设为 50000,使用者可以根据自己需要修改成更大的值
.新特性:增加了 acl_is_blocking() 函数用于判断套接字是阻塞模式还是非阻塞模式
.新特性:acl_vstring.c/vstring_extend 在内存自动增加时,原来采用了内存翻倍增长的方式,当原始内存比较大时容易造成很大内存浪费,现采用了 redis-server 中的策略,在一定范围内(1MB)增长时按翻倍增长方式,超过此范围则以 1MB 为单位进行递增
.问题修复:win32 iocp 模块(events_iocp.c)的函数 stream_on_close 中,应该增加 fdp->event_read 是否为空指针的判断
.问题修复:acl_dbuf_pool.c 在分配内存时存在因整数值溢出而导致的内存非法访问
.编译:整个项目可以使用 clang 编译器编译通过
二、lib_protocol 库
.新特性:在解析 HTTP 请求头的函数 http_hdr_req_line_parse 中,取消了 HTTP 请求方法的限制,从而允许应用可以扩展自己的 HTTP 请求方法
.编译:整个项目可以使用 clang 编译器编译通过
三、lib_acl_cpp 库
.新特性:HttpServlet 类简化了 doRun 参数
.新特性:增加了 dbuf_pool 内存分配类,该类适合于频繁分配大小不一的小内存的情况
.新特性:socket_stream 类增加了 get_tcp_non_blocking 方法用于判断当前套接字是否是非阻塞模式(目前仅支持 UNIX 平台)
.新特性:实现了所有的 redis 客户端协议,总共有 12 个大类,150多个客户端命令,同时支持连接池及连接池集群功能;支持的 12 个大类有:redis_hash/redis_string/redis_hyperloglog/redis_key/redis_list/redis_pubsub/redis_script/redis_server/redis_set/redis_zset/redis_transaction/redis_connection,另外还提供了连接池类 redis_pool 及连接池集群功能类 redis_manager
.新特性:http_header.cpp 中的 set_method 增加了 HEAD/OPTION 请求方法
.新特性:http_client.cpp 增加了 sprint_header 方法,可以将 HTTP 响应头输出至缓冲区内,以便于应用进行调试
.问题修复:db_mysql.cpp 在 WIN32 下使用 mysql 库采用了动态加载的方式,在函数指针前应增加 STDCALL 宏定义
.示例:增加了以下测试 redis 客户端命令的示例:
1、redis_connection:测试 redis 连接类
2、redis_hash:测试 redis 哈希表类
3、redis_hyperloglog:测试 redis hyperloglog 类
4、redis_key:测试 redis 健操作类
5、redis_list:测试 redis 键操作类
6、redis_pubsub:测试 redis 发布/订阅类
7、redis_server:测试 redis 服务管理类
8、redis_set:测试 redis 集合类
9、redis_string:测试 redis 字符串操作类
10、redis_trans:测试 redis 事务类
11、redis_zset:测试 redis 有序集合类
12、redis_zset_pool:使用 redis 有序集合类将大数据块拆分成小数据块,支持连接池方式
13、redis_pool:测试 redis 连接池操作类
14、redis_manager:测试 redis 连接池集群管理类
下载:http://sourceforge.net/projects/acl/
github: https://github.com/zhengshuxin/acl
技术博客:http://zsxxsz.iteye.com/