第1章 源码分析的准备工作 1
1.1 主要特性 1
1.2 源码下载 4
1.3 源码目录结构 5
1.4 源码分析工具 6
1.5 测试辅助工具 7
1.6 编译与执行 8
1.7 其他准备 9
第2章 跟踪与调试 10
2.1 利用gdb调试 10
2.1.1 绑定Nginx到gdb 10
2.1.2 gdb的watch指令 13
2.1.3 Nginx对gdb的支持 14
2.1.4 宏 16
2.1.5 cgdb 18
2.2 利用日志信息跟踪Nginx 19
2.3 利用strace/pstack调试Nginx 21
2.4 获得Nginx程序完整执行流程 23
2.5 加桩调试 29
2.6 特殊应用逻辑的调试 31
第3章 进程模型 35
3.1 整体架构 35
3.2 核心进程模型 36
3.2.1 监控进程 36
3.2.2 工作进程 38
3.3 Cache进程模型 38
3.3.1 Cache管理进程 40
3.3.2 Cache加载进程 42
3.4 进程通信 43
3.5 共享内存 46
3.6 slab机制 50
3.7 信号处理 59
3.7.1 准备工作 60
3.7.2 设置生效 61
3.7.3 处理实例 62
第4章 数据结构 65
4.1 内存池 65
4.2 Hash 72
4.3 Radix tree 77
第5章 配置解析 81
5.1 配置文件格式 81
5.2 配置项目解析准备 84
5.3 配置文件解析流程 86
5.4 配置信息组织结构 95
5.5 配置信息的继承 108
第6章 模块综述 113
6.1 Handler模块 116
6.2 Filter模块 124
6.3 Upstream模块 127
6.4 Load-balance模块 132
第7章 事件管理机制 134
7.1 I/O多路复用模型 134
7.2 epoll模型 138
7.3 事件处理 144
7.4 负载均衡 146
7.4.1 客户端请求均衡 146
7.4.2 多核绑定 152
7.5 超时管理 153
第8章 变量机制 160
8.1 初识变量 160
8.2 支撑机制 163
8.3 脚本引擎 174
8.4 执行顺序 180
第9章 请求处理与响应 182
9.1 创建监听套接口 182
9.2 创建连接套接口 188
9.3 请求处理 191
9.4 数据响应 197
9.5 子请求 201
9.6 连接关闭 214
9.6.1 keepalive机制 217
9.6.2 延迟关闭机制 221
第10章 请求定位 228
10.1 Location的生成 228
10.2 Location的整理 232
10.3 Server的定位 239
10.4 Location的定位与使用 242
10.5 未命名location的使用 244
10.6 try_files指令 248
第11章 动态页面请求处理 252
11.1 测试环境 252
11.2 客户端发起Php请求 255
11.3 请求转发 259
11.3.1 建立连接 261
11.3.2 发送请求数据 265
11.4 数据响应 267
11.4.1 接收并处理Fastcgi响应头 267
11.4.2 接收并发送Fastcgi响应体 273
第12章 过滤模块 283
12.1 ngx_http_not_modified_filter_module 283
12.1.1 304状态码 283
12.1.2 412状态码 285
12.2 ngx_http_headers_filter_module 288
12.2.1 HTTP缓存功能的扩展 289
12.2.2 增加自定义响应头 290
12.3 ngx_http_gzip_filter_module 291
12.4 ngx_http_range_filter_module 293
第13章 负载均衡 299
13.1 负载均衡策略 300
13.2 加权轮询 301
13.2.1 准备工作 301
13.2.2 选择后端服务器 304
13.2.3 后端服务器权值计算 307
13.2.4 释放后端服务器 307
13.3 IP哈希 310
选择后端服务器 310
13.4 两种策略对比 313
第14章 访问控制 315
14.1 禁止指定IP访问 315
14.2 密码认证访问 318
14.3 其他访问控制措施 327
14.3.1 禁止用户通过IP地址访问服务器 327
14.3.2 禁止对某目录或某类文件的访问 327
附录A 329
附录B 332
附录C 333