书籍详情
Apache源代码全景分析:体系结构与核心模块(第1卷)
作者:张中庆,梁雪平 著
出版社:电子工业出版社
出版时间:2009-05-01
ISBN:9787121084744
定价:¥88.00
购买这本书可以去
内容简介
本书是“Apache源代码全景分析”的第1卷。书中详细介绍了Apache的基础体系结构和核心模块的实现机制,包括配置文件、模块化结构、多任务并发,以及网络连接和请求读取,其中多任务并发体系结构是本书分析的重点,讨论了Prefork、Worker及WinNT三种MPM。本书还着重介绍了Apache 2.0新引入的过滤器,包括过滤器的使用、实现,以及其中的数据组织形式——存储段和存储段组,剖析了Apache中常用的过滤器。本书的目的是深入挖掘Apache运行背后的实现机制和模块开发的细节,适合Apache模块开发者、希望了解内部细节的Apache管理员、Web服务器开发者、大规模服务器开发者学习和阅读。
作者简介
张中庆,计算机软件与理论硕士。拥有多年服务器端软件开发经验,关注大规模服务器设计技术,致力于开源技术的使用、分享和推广,《UNIX/Linux下curses库开发指南》第一作者。
目录
第1章 Web服务器概述
1.1 WWW概述
1.1.1 Internet概述
1.1.2 超文本的概念
1.1.3 WWW的历史
1.2 HTTP服务器
1.2.1 HTTP服务器简介
1.2.2 HTTP服务器功能
1.2.3 WWW文档
1.2.4 工作方式
1.3 Apache功能
1.3.1 虚拟主机
1.3.2 内容协商
1.3.3 持续连接
1.3.4 缓存
1.3.5 访问控制和安全
1.3.6 动态内容生成
第2章 Apache体系结构
2.1 Apache目录
2.2 Apache层次结构
2.2.1 操作系统支持层
2.2.2 可移植运行库层
2.2.3 核心功能层
2.2.4 可选功能层
2.2.5 第三方支持库
2.2.6 Apache工具包
2.3 Apache核心功能层
2.3.1 核心与可选模块的关系
2.3.2 核心组件
2.4 Apache运行流程
2.4.1 Apache启动过程
2.4.2 HTTP连接处理
2.4.3 请求报文读取
2.4.4 请求处理
2.4.5 内容生成
2.4.6 关闭与重启
2.5 主程序main
2.5.1 主程序概要
2.5.2 主程序细节
第3章 配置文件管理
3.1 Apache配置系统
3.2 配置文件
3.2.1 配置文件类
3.2.2 配置文件处理时机
3.3 指令相关概念
3.3.1 指令概述
3.3.2 指令参数
3.3.3 指令上下文
3.3.4 指令参数类型
3.4 指令配置
3.4.1 指令结构
3.4.2 指令定义
3.4.3 预定义指令函数
3.4.4 指令表
3.5 Apache配置处理
3.5.1 指令保存
3.5.2 指令读取
3.5.3 配置指令处理
3.5.4 特殊指令
3.6 .htaccess处理
3.6.1 .htaccess使用场合
3.6.2 指令的覆盖
3.6.3 处理.htaccess
3.7 实现自己的配置段
第4章 Apache模块化体系结构
4.1 Apache模块概述
4.1.1 Apache模块组成
4.1.2 Apache核心与模块交互
4.2 Apache模块结构
4.3 模块的加载
4.3.1 模块变量
4.3.2 DSO(Dynamic Shared Object,动态共享对象)的概念
4.3.3 静态模块加载
4.3.4 动态模块加载
4.3.5 模块卸载
4.4 指令表
4.4.1 指令表概述
4.4.2 指令处理函数
4.4.3 指令共享
4.5 挂钩(HOOK)
4.5.1 为什么引入挂钩
4.5.2 声明挂钩
4.5.3 挂钩数组声明(APR—HOOK—LINK)
4.5.4 挂钩结构(APR—HOOK—STRUCT)
4.5.5 挂钩函数注册(APR—IMPLEMENT—EXTERNAL—HOOK—BASE)
4.5.6 使用挂钩
4.5.7 挂钩排序
4.5.8 可选挂钩
4.5.9 挂钩纵览
4.5.10 自己编写挂钩
4.6 模块与配置文件
4.6.1 概述
4.6.2 如何描述配置信息
4.6.3 目录相关配置(Per—Directory Config)
4.6.4 服务器配置(Per-Server Config)
4.7 配置存储和使用
4.7.1 配置向量
4.7.2 配置存储体系结构
4.7.3 虚拟主机配置存储
4.7.4 目录配置存储
4.7.5 Location配置存储
4.7.6 文件配置存储
4.7.7 总体存储示意
4.8 模块通信
4.8.1 简单通信方式
4.8.2 可选函数
4.8.3 提供者API
4.9 常用模块
4.9.1 缓存模块
4.9.2 URL映射模块
4.9.3 内容生成模块
4.9.4 安全模块
4.9.5 代理模块
4.9.6 其余模块
第5章 多任务并发处理
5.1 多进程并发处理
5.1.1 概述
5.1.2 MPM在Apache中的位置
5.2 MPM数据结构
5.2.1 记分板
5.2.2 终止管道(Pipe of Death)
5.3 Inetd:通用的多任务处理结构
5.3.1 服务器程序概述
5.3.2 INETD
5.4 预创建(Prefork)MPM分析
5.4.1 Leader/Follow模式
5.4.2 Prefork MPM概述
5.4.3 Prefork MPM实现
5.5 工作者(Worker):MPM分析
5.5.1 Worker MPM概述
5.5.2 Worker主进程
5.5.3 子进程管理
5.5.4 线程管理
5.5.5 信号处理
5.6 WinNT MPM分析
5.6.1 WinNT MPM概述
5.6.2 完成端口相关概念
5.6.3 WinNT MPM主程序
5.6.4 监控主进程
5.6.5 工作进程
5.6.6 线程处理
第6章 网络连接
6.1 网络连接概述
6.1.1 网络连接上下文环境
6.1.2 等待连接
6.1.3 接受连接
6.1.4 创建连接
6.2 连接数据结构
6.3 等待连接
6.3.1 概述
6.3.2 套接字创建
6.3.3 套接字侦听
6.4 连接处理
6.4.1 连接处理概述
6.4.2 创建连接
6.4.3 连接处理
6.5 请求读取
6.5.1 请求读取概述
6.5.2 HTTP请求报文
6.5.3 request_rec结构
6.5.4 请求读取实现
6.5.5 请求行读取
6.5.6 请求头读取
6.5.7 网络IO读写
第7章 过滤器
7.1 过滤器概述
7.2 过滤器类型
7.3 过滤器结构
7.4 过滤器协议
7.5 过滤器使用
7.5.1 静态过滤器使用
7.5.2 动态过滤器使用
7.6 过滤器操作
7.6.1 过滤器注册概述
7.6.2 数据结构描述
7.6.3 过滤器结点
7.6.4 过滤器注册
7.6.5 过滤器的查找
7.6.6 添加过滤器至指定请求或连接
7.6.7 从连接中删除过滤器
7.6.8 过滤器初始化
7.7 智能过滤器
7.7.1 何谓智能过滤器
7.7.2 智能过滤器的使用
7.7.3 智能过滤器的实现
7.8 过滤器函数
7.8.1 输出过滤器
7.8.2 输入过滤器
第8章 存储段和存储段组
8.1 什么是存储段和存储段组
8.1.1 存储段和存储段组
8.1.2 为什么需要存储段组
8.2 存储段分配子
8.2.1 概述
8.2.2 分配子创建
8.2.3 存储段内存分配
8.2.4 存储段内存释放
8.3 存储段操作概述
8.3.1 存储段接口
8.3.2 存储段空接口
8.4 存储段类型
8.4.1 堆存储段(Heap Bucket)
8.4.2 内存池存储段(Pool Bucket)
8.4.3 文件存储段(File Bucket)
8.4.4 MMAP存储段(MMAP Bucket)
8.4.5 套接字存储段(Socket Bucket)
8.4.6 管道存储段(Pipe Bucket)
8.4.7 持久存储段(Immortal Bucket)
8.4.8 临时存储段(Transient Bucket)
8.4.9 刷新存储段(Flush Bucket)
8.4.10 流终止(EOS)存储段
8.4.11 HTTP错误存储段
8.5 存储段操作
8.6 存储段组操作
8.6.1 创建存储段组
8.6.2 存储段组的销毁
8.6.3 存储段组的分裂
8.6.4 统计存储段长度
8.6.5 存储段转换
8.6.6 数据写入
8.6.7 ap_r函数写入
8.7 存储段组和过滤器
8.7.1 存储段组和过滤器的关系
8.7.2 获取存储段组
8.7.3 存储段组传递
第9章 常用过滤器
9.1 概述
9.2 输入过滤器
9.2.1 CORE_IN输入过滤器
9.2.2 HTTP_IN过滤器
9.2.3 创建自己的输入过滤器
9.3 输出过滤器
9.3.1 资源过滤器
9.3.2 内容过滤器
9.3.3 协议过滤器
9.3.4 编码转换过滤器
9.3.5 网络过滤器(CORE)
9.3.6 编写输出过滤器
索引
1.1 WWW概述
1.1.1 Internet概述
1.1.2 超文本的概念
1.1.3 WWW的历史
1.2 HTTP服务器
1.2.1 HTTP服务器简介
1.2.2 HTTP服务器功能
1.2.3 WWW文档
1.2.4 工作方式
1.3 Apache功能
1.3.1 虚拟主机
1.3.2 内容协商
1.3.3 持续连接
1.3.4 缓存
1.3.5 访问控制和安全
1.3.6 动态内容生成
第2章 Apache体系结构
2.1 Apache目录
2.2 Apache层次结构
2.2.1 操作系统支持层
2.2.2 可移植运行库层
2.2.3 核心功能层
2.2.4 可选功能层
2.2.5 第三方支持库
2.2.6 Apache工具包
2.3 Apache核心功能层
2.3.1 核心与可选模块的关系
2.3.2 核心组件
2.4 Apache运行流程
2.4.1 Apache启动过程
2.4.2 HTTP连接处理
2.4.3 请求报文读取
2.4.4 请求处理
2.4.5 内容生成
2.4.6 关闭与重启
2.5 主程序main
2.5.1 主程序概要
2.5.2 主程序细节
第3章 配置文件管理
3.1 Apache配置系统
3.2 配置文件
3.2.1 配置文件类
3.2.2 配置文件处理时机
3.3 指令相关概念
3.3.1 指令概述
3.3.2 指令参数
3.3.3 指令上下文
3.3.4 指令参数类型
3.4 指令配置
3.4.1 指令结构
3.4.2 指令定义
3.4.3 预定义指令函数
3.4.4 指令表
3.5 Apache配置处理
3.5.1 指令保存
3.5.2 指令读取
3.5.3 配置指令处理
3.5.4 特殊指令
3.6 .htaccess处理
3.6.1 .htaccess使用场合
3.6.2 指令的覆盖
3.6.3 处理.htaccess
3.7 实现自己的配置段
第4章 Apache模块化体系结构
4.1 Apache模块概述
4.1.1 Apache模块组成
4.1.2 Apache核心与模块交互
4.2 Apache模块结构
4.3 模块的加载
4.3.1 模块变量
4.3.2 DSO(Dynamic Shared Object,动态共享对象)的概念
4.3.3 静态模块加载
4.3.4 动态模块加载
4.3.5 模块卸载
4.4 指令表
4.4.1 指令表概述
4.4.2 指令处理函数
4.4.3 指令共享
4.5 挂钩(HOOK)
4.5.1 为什么引入挂钩
4.5.2 声明挂钩
4.5.3 挂钩数组声明(APR—HOOK—LINK)
4.5.4 挂钩结构(APR—HOOK—STRUCT)
4.5.5 挂钩函数注册(APR—IMPLEMENT—EXTERNAL—HOOK—BASE)
4.5.6 使用挂钩
4.5.7 挂钩排序
4.5.8 可选挂钩
4.5.9 挂钩纵览
4.5.10 自己编写挂钩
4.6 模块与配置文件
4.6.1 概述
4.6.2 如何描述配置信息
4.6.3 目录相关配置(Per—Directory Config)
4.6.4 服务器配置(Per-Server Config)
4.7 配置存储和使用
4.7.1 配置向量
4.7.2 配置存储体系结构
4.7.3 虚拟主机配置存储
4.7.4 目录配置存储
4.7.5 Location配置存储
4.7.6 文件配置存储
4.7.7 总体存储示意
4.8 模块通信
4.8.1 简单通信方式
4.8.2 可选函数
4.8.3 提供者API
4.9 常用模块
4.9.1 缓存模块
4.9.2 URL映射模块
4.9.3 内容生成模块
4.9.4 安全模块
4.9.5 代理模块
4.9.6 其余模块
第5章 多任务并发处理
5.1 多进程并发处理
5.1.1 概述
5.1.2 MPM在Apache中的位置
5.2 MPM数据结构
5.2.1 记分板
5.2.2 终止管道(Pipe of Death)
5.3 Inetd:通用的多任务处理结构
5.3.1 服务器程序概述
5.3.2 INETD
5.4 预创建(Prefork)MPM分析
5.4.1 Leader/Follow模式
5.4.2 Prefork MPM概述
5.4.3 Prefork MPM实现
5.5 工作者(Worker):MPM分析
5.5.1 Worker MPM概述
5.5.2 Worker主进程
5.5.3 子进程管理
5.5.4 线程管理
5.5.5 信号处理
5.6 WinNT MPM分析
5.6.1 WinNT MPM概述
5.6.2 完成端口相关概念
5.6.3 WinNT MPM主程序
5.6.4 监控主进程
5.6.5 工作进程
5.6.6 线程处理
第6章 网络连接
6.1 网络连接概述
6.1.1 网络连接上下文环境
6.1.2 等待连接
6.1.3 接受连接
6.1.4 创建连接
6.2 连接数据结构
6.3 等待连接
6.3.1 概述
6.3.2 套接字创建
6.3.3 套接字侦听
6.4 连接处理
6.4.1 连接处理概述
6.4.2 创建连接
6.4.3 连接处理
6.5 请求读取
6.5.1 请求读取概述
6.5.2 HTTP请求报文
6.5.3 request_rec结构
6.5.4 请求读取实现
6.5.5 请求行读取
6.5.6 请求头读取
6.5.7 网络IO读写
第7章 过滤器
7.1 过滤器概述
7.2 过滤器类型
7.3 过滤器结构
7.4 过滤器协议
7.5 过滤器使用
7.5.1 静态过滤器使用
7.5.2 动态过滤器使用
7.6 过滤器操作
7.6.1 过滤器注册概述
7.6.2 数据结构描述
7.6.3 过滤器结点
7.6.4 过滤器注册
7.6.5 过滤器的查找
7.6.6 添加过滤器至指定请求或连接
7.6.7 从连接中删除过滤器
7.6.8 过滤器初始化
7.7 智能过滤器
7.7.1 何谓智能过滤器
7.7.2 智能过滤器的使用
7.7.3 智能过滤器的实现
7.8 过滤器函数
7.8.1 输出过滤器
7.8.2 输入过滤器
第8章 存储段和存储段组
8.1 什么是存储段和存储段组
8.1.1 存储段和存储段组
8.1.2 为什么需要存储段组
8.2 存储段分配子
8.2.1 概述
8.2.2 分配子创建
8.2.3 存储段内存分配
8.2.4 存储段内存释放
8.3 存储段操作概述
8.3.1 存储段接口
8.3.2 存储段空接口
8.4 存储段类型
8.4.1 堆存储段(Heap Bucket)
8.4.2 内存池存储段(Pool Bucket)
8.4.3 文件存储段(File Bucket)
8.4.4 MMAP存储段(MMAP Bucket)
8.4.5 套接字存储段(Socket Bucket)
8.4.6 管道存储段(Pipe Bucket)
8.4.7 持久存储段(Immortal Bucket)
8.4.8 临时存储段(Transient Bucket)
8.4.9 刷新存储段(Flush Bucket)
8.4.10 流终止(EOS)存储段
8.4.11 HTTP错误存储段
8.5 存储段操作
8.6 存储段组操作
8.6.1 创建存储段组
8.6.2 存储段组的销毁
8.6.3 存储段组的分裂
8.6.4 统计存储段长度
8.6.5 存储段转换
8.6.6 数据写入
8.6.7 ap_r函数写入
8.7 存储段组和过滤器
8.7.1 存储段组和过滤器的关系
8.7.2 获取存储段组
8.7.3 存储段组传递
第9章 常用过滤器
9.1 概述
9.2 输入过滤器
9.2.1 CORE_IN输入过滤器
9.2.2 HTTP_IN过滤器
9.2.3 创建自己的输入过滤器
9.3 输出过滤器
9.3.1 资源过滤器
9.3.2 内容过滤器
9.3.3 协议过滤器
9.3.4 编码转换过滤器
9.3.5 网络过滤器(CORE)
9.3.6 编写输出过滤器
索引
猜您喜欢