Nginx是一款功能强大的高性能Web和反向代理服务器,最初由俄罗斯程序员Igor Sysoev开发,而当前由Igor Sysoev领导的专业公司Nginx, Inc.进行持续的维护与更新。
Nginx可以在大多数UNIX或类UNIX系统上编译运行,比如FreeBSD、Solaris、Linux等,并且官方还提供Windows下的可执行版本。目前,Nginx在Netflix 、Wordpress.com、新浪、网易、腾讯、豆瓣等国内外众多知名网站中得到应用。
从源码剖析的角度出发,是程序员常用的学习和提高方法。本书是作者多年研读Nginx源码、深入思考和不断结合实践的结晶。本书重点在于通过剖析Nginx的源码,探究其功能结构及其内部实现原理。
本书内容包括:
◎ 剖析Nginx源码前的准备工作;
◎ 跟踪和调试的方法;
◎ Nginx的整体架构和进程模型;
◎ Nginx的数据结构,包括内存池、Hash 和Radixtree ;
◎ Nginx的配置指令;
◎ Nginx主要功能模块,包括Handler 、Filter 、Load-balance等;
◎ I/O多路复用模型和I/O事件处理等;
◎ 完整的客户端请求分析,包括请求处理与响应、请求定位、动态页面请求处理等;
◎ Filter模块实例;
◎ 负载均衡策略,包括加权轮询策略和IP哈希策略;
◎ Nginx的编译模块、运行配置。
本书适合系统程序员、软件开发工程师、Nginx高级运维工程师阅读参考,对于有志从事相关工作的IT专业学生,更是不可多得的学习资料。
目 录
第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
数据库系统原理(计算机及应用专业独立本科段)2006版全国高等教育自学考试指定教材 内容简介 《2007年版全国高等教育自学考试指定教材:数据库系统原理》是全国...
Theexplosivegrowthofe-commerceandonlineenvironmentshasmadetheissueofinformations...
《世界前沿技术发展报告2007》详细介绍了2007年世界前沿技术的重大进展和发展动向,详细阐述了若干国家科技发展的重要战略和总署
《中国基督教史纲》内容简介:《中国基督教史纲》是我国学者所撰的部也是影响优选的中国基督教通史或全史著作。《中国基督教史纲》
《锁相环:设计、仿真与应用》(第5版)(翻译版)第1章是简短的引言,介绍锁相环领域的情况。第2章安排涉及混合信号锁相环的理论,设
《出世还是入世》内容简介:本书作者何善蒙老师用通俗易懂的语言,讲解以孔孟老庄等十四位中国古代哲人的思想,展现中国先哲的人生
《Java高并发核心编程(卷2)》内容简介:本书聚焦Java高并发编程基础知识,介绍Java多线程、线程池、内置锁、JMM、CAS、JUC、高并
《用户界面设计:有效的人机交互策略(第5版)(英文版)》为了适应因特网和各种移动设备迅猛发展的形势,在第四版的基础上始终以基于
本书首先从软件需求实践中出现的主要问题和困难入手,指出了改进的主要方向;然后逐一说明了需求定义、需求捕获、需求分析与建模
中文版Word 2003实例与操作-(含1CD) 本书特色 《中文版Word 2003实例与操作》:德国亚琛计算机教育中心北京金企鹅文化发展中心联合策划新世纪计...
操作系统导论 本书特色 这是一本关于现代操作系统的书。全书围绕虚拟化、并发和持久性这3个主要概念展开,介绍了所有现代系统的主要组件(包括调度、虚拟内存管理、磁盘...
TounderstandWebdesignitiscriticaltounderstanddesignfirstandtechnologysecond.What...
《3ds Max 2009/VRay(中文版)》内容简介:《3ds Max 2009/VRay中文版效果图灯光、材质、渲染技法精粹张》讲解VRay灯光、材质与渲
编辑推荐生活在昂首阔步,我们在原地驻足停留,有时候,我们要学会与回忆握手言别,将爱存留于心底,带着它赐予我们的力量,前行
《单片机基础及应用项目式教程》内容简介:本书以宏晶公司的STC89C52RC单片机为例,采用“项目和任务驱动”模式编写,将单片机基础
运动人体行为语义计算技术 内容简介 《运动人体行为语义计算技术》主要介绍了运动人体行为的语义计算方法,包括:基于Beowulf机群中改进的粒子滤波的3D人体运动...
Excel2007表格制作图解步步通 本书特色 以全程图解方式介绍excel 2007软件的基础功能与典型应用。以步骤演示的方式引导读者完成表格制作、数据处理和...
《像经营企业一样经营自己》内容简介:时代洪流中,如何做到即便行业遇冷,淘汰谁也轮不到你?在个人品牌崛起的时代,你需要像经营
《激活自愈力:做自己的健康管理师》内容简介:本书纠正了目前大部分人群将健康交付于医生和药物的现象和思维模式,从而忽略了自己
《信息产业部3G移动通信培训指定教材•3G移动通信系统概述》是为了帮助读者了解和掌握第三代移动通信系统三大主流技术的相关基础知