服务器架设笔记——Apache模块开发基础知识
通过上节的例子,我们发现Apache插件开发的一个门槛便是学习它自成体系的一套API。虽然Apache的官网上有对这些API的详细介绍,但是空拿着一些零散的说明书,是很难快速建立起一套可以运行的系统。(转载请指明出于breaksoftware的csdn博客)
为了实现最基础的URL解析等功能,我把《Apache模块开发指南》一书粗略了翻看了两遍,以利于迅速了解Apache模块编程的相关知识。至于书中具体的知识点,我并不在此赘述。但是为了便于大家了解之后遇到的各种相关的知识点,我大致罗列几条(摘自《Apache模块开发指南》一书):
- ap_头文件一般定义了较低层次的API元素,通常(尽管不是总是)被其他头文件包含,而被间接访问。
- http_头文件定义了应用开发者比较感兴趣的绝大部分关键的API。这些API也可以通过一些模块暴露给脚本语言。
- util_头文件定义了比ap_更高层次的API,但是这些API很少被应用模块直接调用,不过这个规则对两个文件例外:util_script.h和util_filter.h。其中util_filter.h定义了过滤API。之后我们会讲过滤器时,就会用到它。
- mod_头文件定义了被可选模块实现的API。使用这些API可能会引发依赖。在之后的章节中我们将会使用到DBD框架导出在mod_dbd.h文件中的API。
- apr_头文件定义了APR(Apache Portable Runtime)的API。对于Web服务器来说,APR库是外部库,也是基本库,并对任何重要的模块来说都是(直接或者间接)必需的。这系列头非常重要。
其中http_头文件又有如下重要的头文件:
- http_config.h:定义了配置API,包括配置数据结构、配置向量、任何相关的访问器。它也定义了它自身的模块数据结构、相关的访问器和处理函数钩子。绝大部分模块都需要这个头文件。
- http_core.h:定义了各种各样被Apache内核引出的API,比如request_rec对象提供的访问器函数。
- http_log.h:定义了错误日志API和管道日志。模块需要这个头文件中的错误报告函数和相关的宏。
- http_protocol.h:包括了一些高层的函数API,用来执行一些重要的操作,包括所有的对客户端的正常I/O,以及处理HTTP协议相关方面,如生成正确的应答报头等。它也导出了一些不在http_request范围内、必需的处理钩子。
我们在前一文《服务器架设笔记——编译Apache及其插件》中我们提到APR库,其全称是Apache Portable Runtime,即Apache可移植运行时库。还有个叫APR-UTIL库,顾名思义,其应该是基于APR库的封装,提供了一套易于使用APR库的方法。我们之后的编程中,将会经常使用到这些库。限于篇幅,我并不打算在此细细讲解这些库。我也只是罗列下《Apache模块开发指南》中的一些知识,相信大家会在其中找到对自己有用的模块。
名称 | 用途 |
---|---|
apr_allocator | 内存分配,内部使用 |
apr_atomic | 原子操作 |
apr_dso | 动态加载链接库 |
apr_env | 读取/设置环境变量 |
apr_errno | 定义错误的值、条件和宏 |
apr_file_info | 文件系统对象和路径的属性 |
apr_file_io | 文件系统输入/输出 |
apr_global_mutex | 全局锁 |
apr_hash | 哈希表 |
apr_inherit | 文件句柄继承辅助 |
apr_mmap | 内存映射 |
apr_network_io | 网络输入/输出(套接字) |
apr_proc_mutex | 进程锁 |
apr_random | 随机数 |
apr_shm | 共享内存 |
apr_signal | 信号处理 |
apr_strings | 字符串操作 |
apr_tables | 表格和数组函数 |
apr_thread_cond | 线程条件 |
apr_thread_mutex | 线程锁 |
apr_thread_proc | 线程和进程函数 |
apr_thread_rwlock | 读写锁 |
apr_time | 时间/日期函数 |
apr_usr | 用户和组ID服务 |
可以见得,APR库主要是对系统的相关操作做了封装,从而实现Portable的能力。
我们再看下APR-UTIL库部分模块(摘自《Apache模块开发指南》一书):
名称 | 用途 |
---|---|
apr_anylock | 透明的、任何锁的封装 |
apr_base64 | Base64编码 |
apr_date | 时间字符串解析 |
apr_dbd | 针对SQL数据库的常用API |
apr_hooks | 钩子实现宏 |
apr_md4 | MD4编码 |
apr_md5 | MD5编码 |
apr_queue | 线程安全的FIFO队列 |
apr_sha1 | SHA1编码 |
apr_strmatch | 字符串模式匹配 |
apr_uri | URI解析/构造 |
apr_uuid | 用户标识 |
apr_xlate | 字符集转换(I18N) |
apr_xml | XML解析 |
我们发现APR和APR-UTIL库为我们提供了从内存分配到线程控制等操作系统相关的模块,也为我们提供了字符串和XML以及一些简单的编码算法库。这些模块可以满足我们一般的需求,我们只要将这些API组合好,使用对,便可以编写Apache插件了。
最后我们要介绍的是APR库的一个基础组件——APR pool。pool就是池,我们在以往的编程中经常会接触到线程池、内存池这样的概念。而APR pool就是APR中各种资源管理的池。作为C/C++程序员,在编程中我们往往需要处理各种内存分配和释放问题——不讨论智能指针这类知识。如果没有深厚的功底和清晰的逻辑,内存泄露就是家常便饭。APR池就是要将程序员这种纠结中解脱出来。所以我们之后在Apache模块编程中,一旦涉及资源申请,就要优先考虑如何去使用这个池。
有了以上的基础知识,我们便可以再小迈一步。下节我将介绍如何编写一个http请求解析插件。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。