acl概述
acl (全称Advanced C Library)是一个跨平台(支持linux,WIN32,Solaris,macOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能库。用户通过该库可以非常容易地编写支持多种模式(多线程、多进程、非阻塞、触发器、UDP方式、协程方式)的服务器程序,WEB 应用程序,数据库应用程序。此外,该库还提供了常见应用的客户端通信库(如:HTTP、SMTP、ICMP、redis、memcache、beanstalk、handler socket),常见流式编解码库(如:XML/JSON/MIME/BASE64/UUCODE/QPCODE/RFC2047),常用数据结构(hash、array、ring、fifo、二分查找、avl、线程池)。
acl库组成
acl 工程主要包含 5 个库及大量示例。5 个库的说明如下:
- lib_acl: 该库是最基础的库,其它 4 个库均依赖于该库; 该库以 C 语言实现。
- lib_protocol: 该库主要实现了 http 协议及 icmp/ping 协议; 该库以 C 语言实现。
- lib_acl_cpp: 该库用 C++ 语言封装了 lib_acl/lib_protocol 两个库,同时增加了一些其它有价值的功能应用。
- lib_fiber: 该库为支持协程库,直接 hook 系统 read/write 等 API,与 epoll 配合支持高并发网络编程。
- lib_dict: 该库主要实现了 KEY-VALUE 的字典式存储库,该库另外还依赖于 BDB, CDB 以及 tokyocabinet 库。
- lib_tls: 该库封装了 openssl 库,使 lib_acl 的通信模式可以支持 ssl。
平台支持及编译
整个工程目前支持 Linux(AS4,5,6, CS4,5,6, ubuntu), windows, MacOS, FreeBSD, Solaris,Android,IOS。
- Linux/UNIX: 编译器为 gcc,直接在终端命令行方式下分别进入 lib_acl/lib_protocol/lib_acl_cpp 目录下,运行 make 命令即可。
- Windows: 可以用 VC2003/VC2008/VC2010/VC2012/vc2013/vc2015 进行编译。
源码目录结构
lib_acl
- init : 主要用于初始化 acl 基础库
- stdlib : 是一些比较基础的功能函数库,在 stdlib/ 根目录下主要包括一些有关日志记录、网络/文件流处理、VSTRING缓冲操作等功能函数;在 stdlib/ 下还有二级目录,如下:
- common : 该目录主要为一些常用的数据结构及算法的功能函数库,象哈希表、链表、队列、动态数组、堆栈、缓存、平衡二叉树、模式匹配树等;
- memory : 该目录主要包含与内存操作相关的函数库,象内存基础分配与校验、内存池管理、内存切片管理等;
- filedir : 该目录主要包含与目录遍历、目录创建等相关的库;
- configure : 该目录主要包含配置文件的分析库;
- iostuff : 该目录主要包含一些常用的IO操作的函数库,象读/写超时、设置IO句柄的阻塞模式等;
- string : 该目录主要包含一些常用的字符串操作的库,提供了比标准C更灵活高效的字符串操作功能;
- debug : 主要用于协助调试内存的泄露等功能;
- sys : 主要是与不同操作系统平台相关的API的封装函数库;
- net: 是与网络操作相关的函数库,包含网络监听、网络连接、DNS查询、套接口参数设置等功能;
- connect : 主要是与网络连接相关的函数库,包含网络连接、域套接口连接等;
- listen : 主要是与网络监听相关的函数库,包含网络监听、域套接口监听等;
- dns : 主要是与DNS域名查询相关的函数库,包含对 gethostbyname 等接口的封装、按RFC1035标准直接发送UDP包方式进行查询等功能;
- event : 主要封装了 select/poll/epoll/iocp/win message/kqueue/devpoll 等系统API接口,使处理网络事件更加灵活、高效、简单,另外还包含定时器接口,acl 中的很多网络应用都会用到这些接口,象 aio、master 等模块;
- aio : 主要包含网络异步操作的功能函数,该套函数库在处理高并发时有非常高的效率,而且提供了比基础API更为高级的调用方式,比使用象 libevent 之类的函数库更为简单,而且是线程安全的;
- msg : 主要包含了基于线程的消息事件及基于网络的消息事件功能;
- thread : 主要是封装了各个OS平台下的基础线程API,使对外接口保持一致性,消除了平台的差异性,同时还提供了半驻留线程池的函数库,以及对于线程局部变量的扩展;
- db : 主要是一些与数据库有关的功能库,定义了一个通用的数据库连接池的框架(并且实现了MySQL的连接池实例);一个简单的内存数据库(由哈希表、链表、平衡二叉树组合而成);ZDB数据存储引擎,这是一个高效的基于数字键的存储引擎;
- proctl : win32 平台下父子进程控制功能库;
- code : 常见编码函数库,包括 base64编解码、URL编解码以及一些汉字字符集编码等;
- unit_test : 包含有关进行 C 语言单元测试的功能库;
- xml: 是一个流式的 xml 解析器及构造器,可以支持阻塞及阻塞式网络通信;
- json: 是一个流式的 json 解析器及构造器,可以支持阻塞及阻塞式网络通信;
- master: 是在 UNIX 环境下支持多种服务器模式的服务器框架,目前主要支持多进程模式、多进程多线程模式、多进程非阻塞模式、多进程触发器模式及 UDP 通信模式;
lib_protocol
- http: HTTP 协议相关的库,支持 HTTP/1.1,通讯方式支持同步/异步方式
- icmp: icmp/ping 协议库,支持同步/异步通信方式
- smtp: 邮件客户端发信协议库
lib_fiber
- c 目录:该目录下主要为 C 语言版本实现的网络协程库,其中包含源文件及头文件
- cpp 目录:该目录下封装了 C 语言版本的网络协程库
- samples 目录:该目录下有大量的使用协程库编程的例子
samples
- lib_acl/samples:该目录下的程序主要是基于 lib_acl 及 lib_protocol 库的示例
- lib_acl_cpp/samples:该目录下的程序主要是基于 lib_acl_cpp 库的示例