阅读更多

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 连接池操作类

14、redis_manager:测试 redis 连接池集群管理类

下载:http://sourceforge.net/projects/acl/

github: https://github.com/zhengshuxin/acl

技术博客:http://zsxxsz.iteye.com/

1
0
评论 共 0 条 请登录后发表评论

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 跨平台网络通信与服务器框架(acl) 新版本发布

    acl(one advanced C/C++ library) 是一个跨平台的网络通信与服务器开发开源框架,至今已经被很多大公司所使用,使开发者在享受C/C++的高性能的同时,可以使用 acl 框架提高开发效率与系统的稳定性。该框架不仅提供...

  • SpringBoot所有知识点详解,根据狂神说java老师的整理

    Spring是一个开源框架,2003 年兴起的一个轻量级的Java 开发框架,作者:Rod Johnson 。 Spring是为了解决企业级应用开发的复杂性而创建的,简化开发。 1.2、Spring是如何简化Java开发的 为了降低Java开发的复杂性,...

  • Redis 6——入门介绍

    网络相关配置 4.3.1.bind 4.3.2.protected-mode 4.3.3.Port 4.3.4.tcp-backlog 4.3.5.timeout 4.3.6.tcp-keepalive 4.4.GENERAL 通用 4.4.1.daemonize 4.4.2.pidfile 4.4.3.loglevel 4.4.4.logfile 4.4.5.databases ...

  • 分享国外安全团队及工具

    BAMF框架 35.30d2b4b 模块化框架,旨在成为发起针对僵尸网络的攻击的平台。  https://github.com/bwall/BAMF basedomainname 0.1 可从完全限定的域名中提取TLD(顶级域),域扩展(二级域+ TLD),域名和...

  • 十八、redis6从入门到高级

    加上后来的智能移动设备的普及,所有的互联网平台都面临了巨大的性能挑战。 ⑶ 解决CPU及内存压力 ⑷ 解决IO压力 2、NoSQL数据库 ⑴ NoSQL数据库概述 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非...

  • Redis学习笔记

    一、安装Redis 1.1 下载压缩包 先在VM虚拟机里安装Centos7,并且SecureCRT连接上Centos 1.从百度网盘下载redis-6.2.1.tar.gz到桌面 2.通过SecureFX工具,把压缩包上传到Linux系统的/...3.gcc --version 看到版本4.8.5

  • Hadoop 入门笔记

    hadoop是什么 1)Hadoop是一个由Apache基金回收研发的分布式基础架构 所谓分布式计算就是在两个或多个软件互相共享信息,这些软件既可以在同一台计算机上运行,也可以在通过网络连接起来的多台计算机上运行 2)主要...

  • Spring Boot启动参考指南(官方版)

    10.3从较早版本的SpringBoot升级 11.开发您的第一个SpringBoot应用程序 11.1创建POM 11.2添加类路径依赖项 11.3编写守则 11.3.1@RestController和@Requestmap注释 11.3.2@EnableAutoConfiguration...

  • Notes Twenty one days-渗透攻击-红队-权限提升

    ** Notes Twentieth Day-渗透攻击-红队-权限提升(dayu) ...不要未经授权在真实网络环境中复现任何本书中描述的攻击。即使是出于好奇而不是恶意,你仍然会因未授权测试行为而陷入很多麻烦。为了个人能更

  • pandas-1.3.5-cp37-cp37m-macosx_10_9_x86_64.zip

    pandas whl安装包,对应各个python版本和系统(具体看资源名字),找准自己对应的下载即可! 下载后解压出来是已.whl为后缀的安装包,进入终端,直接pip install pandas-xxx.whl即可,非常方便。 再也不用担心pip联网下载网络超时,各种安装不成功的问题。

  • 基于java的大学生兼职信息系统答辩PPT.pptx

    基于java的大学生兼职信息系统答辩PPT.pptx

  • 基于java的乐校园二手书交易管理系统答辩PPT.pptx

    基于java的乐校园二手书交易管理系统答辩PPT.pptx

  • tornado-6.4-cp38-abi3-musllinux_1_1_i686.whl

    tornado-6.4-cp38-abi3-musllinux_1_1_i686.whl

  • Android Studio Ladybug(android-studio-2024.2.1.10-mac.zip.002)

    Android Studio Ladybug 2024.2.1(android-studio-2024.2.1.10-mac.dmg)适用于macOS Intel系统,文件使用360压缩软件分割成两个压缩包,必须一起下载使用: part1: https://download.csdn.net/download/weixin_43800734/89954174 part2: https://download.csdn.net/download/weixin_43800734/89954175

  • 基于ssm框架+mysql+jsp实现的监考安排与查询系统

    有学生和教师两种角色 登录和注册模块 考场信息模块 考试信息模块 点我收藏 功能 监考安排模块 考场类型模块 系统公告模块 个人中心模块: 1、修改个人信息,可以上传图片 2、我的收藏列表 账号管理模块 服务模块 eclipse或者idea 均可以运行 jdk1.8 apache-maven-3.6 mysql5.7及以上 tomcat 8.0及以上版本

  • tornado-6.1b2-cp38-cp38-macosx_10_9_x86_64.whl

    tornado-6.1b2-cp38-cp38-macosx_10_9_x86_64.whl

  • Android Studio Ladybug(android-studio-2024.2.1.10-mac.zip.001)

    Android Studio Ladybug 2024.2.1(android-studio-2024.2.1.10-mac.dmg)适用于macOS Intel系统,文件使用360压缩软件分割成两个压缩包,必须一起下载使用: part1: https://download.csdn.net/download/weixin_43800734/89954174 part2: https://download.csdn.net/download/weixin_43800734/89954175

  • 基于MATLAB车牌识别代码实现代码【含界面GUI】.zip

    matlab

  • 基于java的毕业生就业信息管理系统答辩PPT.pptx

    基于java的毕业生就业信息管理系统答辩PPT.pptx

Global site tag (gtag.js) - Google Analytics