`
zsxxsz
  • 浏览: 451053 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

acl 框架库简介

阅读更多

 一、概述

    acl 工程是一个跨平台的通用网络通信库及服务器编程框架,同时提供更多的其它有价值功能。通过该库,用户可以非常容易地编写支持多种模式的服务器程序、WEB 应用程序以及数据库应用程序。此外,该库还提供了 XML/JSON/MIME 编码及解码功能,这些编码解码库均支持流式解析模式,从而使之更适应不同的网络通讯方式。

    本工程主要包含 5 个库及大量示例。5 个库的说明如下:

    1) lib_acl: 该库是最基础的库,其它 4 个库均依赖于该库; 该库以 C 语言实现。

    2) lib_protocol: 该库主要实现了 http/ping/smtp 协议; 该库以 C 语言实现。

    3) lib_acl_cpp: 该库用 C++ 语言封装了 lib_acl/lib_protocol 两个库,同时增加了一些其它有价值的功能应用。

    4) lib_fiber: 该库为高性能的网络协程库,支持大并发、高性能。

    5) lib_dict: 该库主要实现了 KEY-VALUE 的字典式存储库,该库另外还依赖于 BDB, CDB 以及 tokyocabinet 库。

    6) lib_tls: 该库封装了 openssl 库,使 lib_acl 的通信模式可以支持 ssl。

 

二、平台支持及编译

    整个工程目前支持 Linux(AS4/5/6, CS4/5/6), Windows, MacOS, FreeBSD, Solaris X86。

    1) Linux/Unix: 直接在终端命令行方式下分别进入 lib_acl/lib_protocol/lib_acl_cpp/lib_dict/lib_tls 目录下,运行 make 命令即可。

    2) Windows: 可以用 VC2003/VC2008/VC2010/vc2012 进行编译。(如果您需要用 VC6/VC2002/VC2005 编译,可以参考 VC2003 的编译条件)。

    当在 WIN32 环境下使用动态库时有几点需要注意:

    a) 使用 lib_acl 的动态库时,需要在用户的工程预定义: ACL_DLL;

    b) 使用 lib_protocol 动态库中的 HTTP 库,SMTP库或 ICMP 库时,需要在工程中预定义 HTTP_DLL 、SMTP_DLL或 ICMP_DLL;

    c) 使用 lib_acl_cpp 的动态库时,需要在工程中预定义 ACL_CPP_DLL;

    d) 使用 lib_dict 的动态库时,需要在工程中预定义 DICT_DLL;

    e) 使用 lib_tls 的动态库时,需要在工程中预定义 TLS_DLL。

 

三、本工程目录结构说明

    1) lib_acl/src

    1.1 init:主要用于初始化 acl 基础库

    1.2 stdlib:是一些比较基础的功能函数库,在 stdlib/ 根目录下主要包括一些有关日志记录、网络/文件流处理、VSTRING缓冲操作等功能函数;在 stdlib/ 下还有二级目录,如下:

    1.2.1 common:该目录主要为一些常用的数据结构及算法的功能函数库,象哈希表、链表、队列、动态数组、堆栈、缓存、平衡二叉树、模式匹配树等;

    1.2.2 memory:该目录主要包含与内存操作相关的函数库,象内存基础分配与校验、内存池管理、内存切片管理等;

    1.2.3 filedir:该目录主要包含与目录遍历、目录创建等相关的库;

    1.2.4 configure:该目录主要包含配置文件的分析库;

    1.2.5 iostuff:该目录主要包含一些常用的IO操作的函数库,象读/写超时、设置IO句柄的阻塞模式等;

    1.2.6 string:该目录主要包含一些常用的字符串操作的库,提供了比标准C更灵活高效的字符串操作功能;

    1.2.7 debug:主要用于协助调试内存的泄露等功能;

    1.2.8 sys:主要是与不同操作系统平台相关的API的封装函数库;

    1.3 net:是与网络操作相关的函数库,包含网络监听、网络连接、DNS查询、套接口参数设置等功能;

    1.3.1 connect:主要是与网络连接相关的函数库,包含网络连接、域套接口连接等;

    1.3.2 listen:主要是与网络监听相关的函数库,包含网络监听、域套接口监听等;

    1.3.3 dns:主要是与DNS域名查询相关的函数库,包含对 gethostbyname 等接口的封装、按RFC1035标准直接发送UDP包方式进行查询等功能;

    1.4 event:主要封装了 select/poll/epoll/iocp/win32 message/kqueue/devpoll 等系统API接口,使处理网络事件更加灵活、高效、简单,另外还包含定时器接口,acl 中的很多网络应用都会用到这些接口,如 aio、master 等模块;

    1.5 aio:主要包含网络异步操作的功能函数,该套函数库在处理高并发时有非常高的效率,而且提供了比基础API更为高级的调用方式,比使用象 libevent 之类的函数库更为简单,而且是线程安全的;

    1.6 msg:主要包含了基于线程的消息事件及基于网络的消息事件功能;

    1.7 thread:主要是封装了各个OS平台下的基础线程API,使对外接口保持一致性,消除了平台的差异性,同时还提供了半驻留线程池的函数库,以及对于线程局部变量的扩展;

    1.8 db:主要是一些与数据库有关的功能库,定义了一个通用的数据库连接池的框架(并且实现了mysql的连接池实例);一个简单的内存数据库(由哈希表、链表、平衡二叉树组合而成);ZDB数据存储引擎,这是一个高效的基于数字键的存储引擎;

    1.9 proctl:win32 平台下父子进程控制功能库;

    1.10 code:常见编码函数库,包括 base64编解码、URL编解码以及一些汉字字符集编码等;

    1.11 unit_test:包含有关进行 C 语言单元测试的功能库;

    1.12 xml :是一个流式的 xml 解析器及构造器,可以支持阻塞及阻塞式网络通信;

    1.13 json :是一个流式的 json 解析器及构造器,可以支持阻塞及阻塞式网络通信;

    1.14 master:是在 UNIX 环境下支持多种服务器模式的服务器框架(基于 POSTFIX 的服务器框架改造),目前主要支持多进程模式、多进程多线程模式、多进程非阻塞模式、UDP通信模式以及多进程触发器模式;

 

    2) lib_protocol/src

    2.1 http:HTTP 协议相关的库,支持 HTTP/1.1,通讯方式支持同步/异步方式

    2.2 icmp:icmp/ping 协议库,支持同步/异步通信方式

    2.3 smtp:支持 SMTP 客户端通信库

 

    3) lib_acl_cpp/src

    3.1 stdlib:主要包含字符串处理类(string),xml/json 解析库,zlib 压缩库(依赖于 zlib 库), 日志记录类, 字符集转码(在UNIX环境下需要 iconv 库), 线程类/线程池类, 互斥类(支持线程锁、文件锁);

    3.2 mime:支持完整的与邮件编码相关的库(邮件的 rfc2045-rfc2047/rfc822/base64/uucode 编码及解码库);

    3.3 master:封装了 C 版 lib_acl 库中的服务器框架,支持进程池模式、线程池模式、非阻塞模式、UDP 通信模式以及触发器模式;

    3.4 stream:支持网络流/文件流,支持阻塞/非阻塞两种通信方式,在非阻塞模式下支持 select/poll/epoll/iocp/win32 message/kqueue/devpoll;支持 ssl 加密传输(阻塞及非阻塞方式,需要 polarssl库);

    3.5 ipc:在非阻塞通信方式,提供了阻塞模块与非阻塞模块整合的方式;

    3.6 http:比较完整的 HTTP 通信库及协议解析库,支持客户端及服务端模式,支持 ssl/gzip 传输方式; 支持类似于 Java HttpServlet 方式的大部分接口,方便编写 CGI 及服务器程序;

    3.7 db:封装了 MYSQL/SQLITE 库,支持数据库连接池;

    3.8 hsocket:实现了完整的 handler-socket 客户端通信库;

    3.9 beanstalk:支持消息队列服务器 beanstalkd 的客户端通信库;

    3.10 connpool:通用的 TCP 连接池框架;

    3.11 memcache:支持 memcached 通信协议的客户端库(支持连接池);

    3.12 queue:磁盘文件队列管理器;

    3.13 session:会话管理器,目前支持使用 memcache 客户端库存储会话数据。

 

    4) lib_fiber

    4,1) c: 该目录主要是支持 C 语言的网络协程库

    4.2) cpp: 该目录使用 C++ 对 C 协程库进行了封装

    4.3) samples: 该目录有大量的使用协程的例子

    4.4) 有关协程的更多内容,参考:http://zsxxsz.iteye.com/category/360229

    5) lib_acl/samples:该目录下的程序主要是基于 lib_acl 及 lib_protocol 库的示例

    6) lib_acl_cpp/samples:该目录下的程序主要是基于 lib_acl_cpp 库的示例

 
下载:http://sourceforge.net/projects/acl/
qq 群242722074
国内镜像:http://git.oschina.net/acl-dev/acl/tree/master
微博:http://weibo.com/zsxxsz/
5
1
分享到:
评论
3 楼 zsxxsz 2013-11-18  
bzglufoken 写道
性能及稳定性怎样?是否适合用于生产生产环境?有成功案例吗?

有一些大公司在用了。
2 楼 bzglufoken 2013-11-18  
性能及稳定性怎样?是否适合用于生产生产环境?有成功案例吗?
1 楼 sunzihao128858 2013-06-22  
不错。     

相关推荐

    acl框架库是一个C语言网络框架库,主要包含:服务器开发框架、同步异步网络通讯、常用数据结构、进程池线程池、流式xmljson

    ACL框架库是一个专为C语言设计的网络框架,它提供了丰富的功能,使开发者能够更高效地构建网络应用程序。这个框架的核心特性包括服务器开发框架、同步和异步网络通信机制、常用的数据结构、进程池和线程池管理,以及...

    acl 框架库 v3.6.1.6.zip

    `acl-v3.6.1-6`文件可能是一个包含源代码的目录,提供了整个ACL框架库的源代码。通过阅读源代码,开发者可以深入理解库的工作原理,查找并修复潜在的bug,或者根据自己的需求进行定制。源代码通常按照模块划分,如...

    acl 框架库-其他

    acl 框架库是一个 C 库,主要包含:服务器开发框架、同步/异步网络通讯、常用数据结构、进程池/线程池、流式 xml/json 解析器、http/ping 应用协议等内容。 acl 包括以下丰富的常用函数库: 1、常见网络应用库:SMTP...

    acl 框架库 v3.5.2.0-源码.zip

    解压后,我们可以预期找到ACL框架库的全部源代码文件,可能包括C++、Java、Python或其他编程语言的源代码,以及相关的构建脚本、配置文件、文档等。 源码分析: 1. **设计模式**:ACL框架可能采用了如工厂模式、...

    acl C++跨平台库.rar

    acl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能库。通过该库,用户可以非常容易地编写支持多种模式(多线程、多进程、非阻塞、触发器、...

    acl库 (advanced c library)

    ACL库,全称为Advanced C Library,是一个为C程序员设计的跨平台库,旨在提供一系列高效且易用的数据处理算法,以及强大的服务器框架。这个库特别适合于开发需要高性能、高并发性和良好扩展性的网络应用程序。在本文...

    acl 2.1.2.8 源码

    acl 框架库是一个 C 库,主要包含:服务器开发框架、同步/异步网络通讯、常用数据结构、进程池/线程池、流式 xml/json 解析器、http/ping 应用协议等内容;

    acl-3.0.19

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

    cpp-acl工程是一个跨平台的网络通信库及服务器编程框架

    acl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能库。通过该库,用户可以非常容易地编写支持多种模式(多线程、多进程、非阻塞、触发器、...

    网络与服务器编程框架库

    在IT行业中,网络与服务器编程框架库是构建高效、稳定且可扩展的网络服务的核心工具。这些库提供了丰富的功能,使开发者能够轻松处理网络通信、数据传输和服务器管理等复杂任务。下面我们将深入探讨网络通信库和...

    acl-master_网络通信框架_aclmaster_

    acl 工程是一个跨平台的通用网络通信库,同时提供更多的其它有价值功能。通过该库,用户可以非常容易地编写支持多种模式的服务器程序、WEB 应用程序以及数据库应用程序。此外,该库还提供了 XML/JSON/MIME 编码及...

    acl 工程是一个跨平台的网络通信库及服务器编程框架,同时提供更多的实用功能库

    acl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能库。通过该库,用户可以非常容易地编写支持多种模式(多线程、多进程、非阻塞、触发器、...

    acl.2.1.2.8.src.2012.7.2.zip_ACL_ACL_http_http json_协议

    以下是ACL框架库的主要组成部分和相关知识点的详细解释: 1. **服务器开发框架**:ACL提供了基础的服务器架构,允许开发者快速搭建网络服务器。它支持TCP和UDP等传输层协议,可以处理并发连接,同时提供了事件驱动...

    acl_cpp:用于win32 / linux,服务器框架,HttpServlet的功能强大的c ++库-开源

    acl_cpp(已包含在acl项目中:https://sourceforge.net/projects/acl/,请从acl项目url下载)是acl的c ++包装库,并且acl_cpp比acl具有更多有用的功能,例如例如流式mime解析,处理程序套接字支持以及db(mysql和...

    lua and acl example

    标题“lua and acl example”揭示了本主题是关于使用Lua脚本语言与Access Control Lists (ACL)相结合的一个示例。Lua是一种轻量级的、解释型的编程语言,常用于游戏开发、配置文件、服务器应用等领域。而ACL则通常...

    acl-master.zip

    acl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能库。通过该库,用户可以非常容易地编写支持多种模式(多线程、多进程、非阻塞、触发器、...

    acl-master

    acl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能库。通过该库,用户可以非常容易地编写支持多种模式(多线程、多进程、非阻塞、触发器、...

    spring security acl

    Spring Security ACL是Spring Security框架的一个重要组成部分,它提供了一种细粒度的访问控制机制,允许开发者对应用程序的数据对象进行权限管理。在Spring Security ACL中,你可以定义哪些用户或角色可以对特定的...

    Laravel开发-laravel-acl

    Laravel 社区中有多个优秀的 ACL 库,如 `spatie/laravel-permission`。首先,你需要通过 Composer 来安装这个库: ``` composer require spatie/laravel-permission ``` 2. **配置与迁移** 安装完成后,需要...

    acl工程是一个跨平台的网络通信库及服务器编程框架,同时提供更多的实用功能库,支持LINUX,WIN32,Solaris,Mac

    cl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能库。通过该库,用户可以非常容易地编写支持多种模式(多线程、多进程、非阻塞、触发器、UDP...

Global site tag (gtag.js) - Google Analytics