
编辑推荐
《深入理解Nginx:模块开发与架构解析(第2版)》由陶辉编著,机械工业出版社出版。
名人推荐
Nginx一直是高性能服务器的工程典范,它充分利用了操作系统和硬件提供的特性,涉及的知识面非常多,要领略到真正的风景需要艰难的跋涉,本书是很好的向导,一路陪伴着,适时地告诉你哪里是风景,哪里是坑,让你快乐地走完旅程。
——阿里云飞天事业部研究员 褚霸
Nginx自面世以来,就以高性能的Web服务器著称,然而由于功能强大,插件结构比较复杂,也使众多初学者很难快速入门。为了让广大读者了解Nginx的全貌并迅速投入相关的开发和运维工作中,本书作者通过图文并茂的方式由浅入深地向读者揭开了Nginx的面纱,先从Nginx服务器的配置人手,再到开发简单的HTTP Server,最后介绍Nginx的内存分配原理,既剖析了Nginx,又对如何进行高性能服务器编程进行了很好地阐述,相信对各个层次的读者都有很大的帮助,感谢陶辉!
——阿里巴巴集团核心系统部资深专家 伯瑜
Nginx作为一款面向性能设计的HTTP服务器,不但在稳定性和性能方面相当出众,而且它模块化的设计让其具有异常灵活的扩展性。本书的作者,通过大量的示例和经验,介绍了Nginx的设计思路和相关编程技巧,以及如何开发Nginx模块。看完这本书,你不但能对Nginx有一个全面了解,更重要的是可以学到Nginx的设计思路和理念,这对于任何一个想在软件设计上有所提高的程序员来说都是非常有价值的。
——酷壳网站站长 陈皓
作者简介
陶辉,毕业于西安交通大学计算机科学与技术专业,曾就职于华为中央软件部、腾讯QQ空间、思科中国CRDC等公司,目前在阿里巴巴云计算公司的飞天团队工作,研究方向为介于Iaas和Paas间的弹性计算,多年以来专注于Nginx的定制化应用,对Nginx的设计与特性有深刻认识,实战经验丰富,编写过许多优秀的Nginx模块并应用于企业级产品中,同时撰写了大量关于Nginx的技术文章。擅长Linux下高性能服务器的开发,以及分布式环境下海量数据存储的设计开发。
目录
前言
第一部分Nginx能帮我们做什么
第1章研究Nginx前的准备工作2
1.1Nginx是什么2
1.2为什么选择Nginx5
1.3准备工作7
1.3.1Linux操作系统7
1.3.2使用Nginx的必备软件7
1.3.3磁盘目录8
1.3.4Linux内核参数的优化9
1.3.5获取Nginx源码10
1.4编译安装Nginx11
1.5configure详解11
1.5.1configure的命令参数11
1.5.2configure执行流程18
1.5.3configure生成的文件21
1.6Nginx的命令行控制23
1.7小结27
第2章Nginx的配置28
2.1运行中的Nginx进程间的关系28
2.2Nginx配置的通用语法31
2.2.1块配置项31
2.2.2配置项的语法格式32
2.2.3配置项的注释33
2.2.4配置项的单位33
2.2.5在配置中使用变量33
2.3Nginx服务的基本配置34
2.3.1用于调试进程和定位问题的配置项34
2.3.2正常运行的配置项36
2.3.3优化性能的配置项37
2.3.4事件类配置项39
2.4用http核心模块配置一个静态Web服务器40
2.4.1虚拟主机与请求的分发41
2.4.2文件路径的定义45
2.4.3内存及磁盘资源的分配47
2.4.4网络连接的设置49
2.4.5MIME类型的设置52
2.4.6对客户端请求的限制53
2.4.7文件操作的优化54
2.4.8对客户端请求的特殊处理56
2.4.9ngx_http_core_module模块提供的变量57
2.5用httpproxymodule配置一个反向代理服务器59
2.5.1负载均衡的基本配置61
2.5.2反向代理的基本配置63
2.6小结66
第二部分如何编写http模块
第3章开发一个简单的http模块68
3.1如何调用http模块68
3.2准备工作70
3.2.1整型的封装71
3.2.2ngx_str_t数据结构71
3.2.3ngx_list_t数据结构71
3.2.4ngx_table_elt_t数据结构75
3.2.5ngx_buf_t数据结构75
3.2.6ngx_chain_t数据结构77
3.3如何将自己的http模块编译进Nginx77
3.3.1config文件的写法77
3.3.2利用configure脚本将定制的模块加入到Nginx中78
3.3.3直接修改Makefile文件81
3.4http模块的数据结构82
3.5定义自己的http模块86
3.6处理用户请求89
3.6.1处理方法的返回值89
3.6.2获取URI和参数92
3.6.3获取http头部94
3.6.4获取http包体97
3.7发送响应99
3.7.1发送http头部99
3.7.2将内存中的字符串作为包体发送101
3.7.3经典的“HelloWorld”示例102
3.8将磁盘文件作为包体发送103
3.8.1如何发送磁盘中的文件104
3.8.2清理文件句柄106
3.8.3支持用户多线程下载和断点续传107
3.9用C++语言编写http模块108
3.9.1编译方式的修改108
3.9.2程序中的符号转换109
3.10小结110
第4章配置、error日志和请求上下文111
4.1http配置项的使用场景111
4.2怎样使用http配置113
4.2.1分配用于保存配置参数的数据结构113
4.2.2设定配置项的解析方式115
4.2.3使用14种预设方法解析配置项121
4.2.4自定义配置项处理方法131
4.2.5合并配置项133
4.3http配置模型135
4.3.1解析http配置的流程136
4.3.2http配置模型的内存布局139
4.3.3如何合并配置项142
4.3.4预设配置项处理方法的工作原理144
4.4error日志的用法145
4.5请求的上下文149
4.5.1上下文与全异步Web服务器的关系149
4.5.2如何使用http上下文151
4.5.3http框架如何维护上下文结构152
4.6小结153
第5章访问第三方服务154
5.1upstream的使用方式155
5.1.1ngx_http_upstream_t结构体158
5.1.2设置upstream的限制性参数159
5.1.3设置需要访问的第三方服务器地址160
5.1.4设置回调方法161
5.1.5如何启动upstream机制161
5.2回调方法的执行场景162
5.2.1create_request回调方法162
5.2.2reinit_request回调方法164
5.2.3finalize_request回调方法165
5.2.4process_header回调方法165
5.2.5rewrite_redirect回调方法167
5.2.6input_filter_init与input_filter回调方法167
5.3使用upstream的示例168
5.3.1upstream的各种配置参数168
5.3.2请求上下文170
5.3.3在create_request方法中构造请求170
5.3.4在process_header方法中解析包头171
5.3.5在finalize_request方法中释放资源175
5.3.6在ngx_http_mytest_handler方法中启动upstream175
5.4subrequest的使用方式177
5.4.1配置子请求的处理方式177
5.4.2实现子请求处理完毕时的回调方法178
5.4.3处理父请求被重新激活后的回调方法179
5.4.4启动subrequest子请求179
5.5subrequest执行过程中的主要场景180
5.5.1如何启动subrequest180
5.5.2如何转发多个子请求的响应包体182
5.5.3子请求如何激活父请求185
5.6subrequest使用的例子187
5.6.1配置文件中子请求的设置187
5.6.2请求上下文188
5.6.3子请求结束时的处理方法188
5.6.4父请求的回调方法189
5.6.5启动subrequest190
5.7小结191
第6章开发一个简单的http过滤模块192
6.1过滤模块的意义192
6.2过滤模块的调用顺序193
6.2.1过滤链表是如何构成的194
6.2.2过滤链表的顺序196
6.2.3官方默认http过滤模块的功能简介197
6.3http过滤模块的开发步骤198
6.4http过滤模块的简单例子200
6.4.1如何编写config文件201
6.4.2配置项和上下文201
6.4.3定义http过滤模块203
6.4.4初始化http过滤模块204
6.4.5处理请求中的http头部204
6.4.6处理请求中的http包体206
6.5小结206
第7章Nginx提供的高级数据结构207
7.1Nginx提供的高级数据结构概述207
7.2ngx_queue_t双向链表209
7.2.1为什么设计ngx_queue_t双向链表209
7.2.2双向链表的使用方法209
7.2.3使用双向链表排序的例子212
7.2.4双向链表是如何实现的213
7.3ngx_array_t动态数组215
7.3.1为什么设计ngx_array_t动态数组215
7.3.2动态数组的使用方法215
7.3.3使用动态数组的例子217
7.3.4动态数组的扩容方式218
7.4ngx_list_t单向链表219
7.5ngx_rbtree_t红黑树219
7.5.1为什么设计ngx_rbtree_t红黑树219
7.5.2红黑树的特性220
7.5.3红黑树的使用方法222
7.5.4使用红黑树的简单例子225
7.5.5如何自定义添加成员方法226
7.6ngx_radix_tree_t基数树228
7.6.1ngx_radix_tree_t基数树的原理228
7.6.2基数树的使用方法230
7.6.3使用基数树的例子231
7.7支持通配符的散列表232
7.7.1ngx_hash_t基本散列表232
7.7.2支持通配符的散列表235
7.7.3带通配符散列表的使用例子241
7.8小结245
第三部分深入Nginx
第8章Nginx基础架构248
8.1Web服务器设计中的关键约束249
8.2Nginx的架构设计251
8.2.1优秀的模块化设计251
8.2.2事件驱动架构254
8.2.3请求的多阶段异步处理256
8.2.4管理进程、多工作进程设计259
8.2.5平台无关的代码实现259
8.2.6内存池的设计259
8.2.7使用统一管道过滤器模式的http过滤模块260
8.2.8其他一些用户模块260
8.3Nginx框架中的核心结构体ngx_cycle_t260
8.3.1ngx_listening_t结构体261
8.3.2ngx_cycle_t结构体262
8.3.3ngx_cycle_t支持的方法264
8.4Nginx启动时框架的处理流程266
8.5worker进程是如何工作的269
8.6master进程是如何工作的271
8.7ngx_pool_t内存池276
8.8小结284
第9章事件模块285
9.1事件处理框架概述286
9.2Nginx事件的定义288
9.3Nginx连接的定义291
9.3.1被动连接292
9.3.2主动连接295
9.3.3ngx_connection_t连接池296
9.4ngx_events_module核心模块297
9.4.1如何管理所有事件模块的配置项299
9.4.2管理事件模块300
9.5ngx_event_core_module事件模块302
9.6epoll事件驱动模块308
9.6.1epoll的原理和用法308
9.6.2如何使用epoll310
9.6.3ngx_epoll_module模块的实现312
9.7定时器事件320
9.7.1缓存时间的管理320
9.7.2缓存时间的精度323
9.7.3定时器的实现323
9.8事件驱动框架的处理流程324
9.8.1如何建立新连接325
9.8.2如何解决“惊群”问题327
9.8.3如何实现负载均衡329
9.8.4post事件队列330
9.8.5ngx_process_events_and_timers流程331
9.9文件的异步I/O334
9.9.1Linux内核提供的文件异步I/O335
9.9.2ngx_epoll_module模块中实现的针对文件的异步I/O337
9.10TCP协议与Nginx342
9.11小结347
第10章http框架的初始化348
10.1http框架概述349
10.2管理http模块的配置项352
10.2.1管理main级别下的配置项353
10.2.2管理server级别下的配置项355
10.2.3管理location级别下的配置项358
10.2.4不同级别配置项的合并364
10.3监听端口的管理367
10.4server的快速检索370
10.5location的快速检索370
10.6http请求的11个处理阶段372
10.6.1http处理阶段的普适规则374
10.6.2NGX_http_POST_READ_PHASE阶段375
10.6.3NGX_http_SERVER_REWRITE_PHASE阶段378
10.6.4NGX_http_FIND_CONFIG_PHASE阶段378
10.6.5NGX_http_REWRITE_PHASE阶段378
10.6.6NGX_http_POST_REWRITE_PHASE阶段379
10.6.7NGX_http_PREACCESS_PHASE阶段379
10.6.8NGX_http_ACCESS_PHASE阶段379
10.6.9NGX_http_POST_ACCESS_PHASE阶段380
10.6.10NGX_http_TRY_FILES_PHASE阶段380
10.6.11NGX_http_CONTENT_PHASE阶段380
10.6.12NGX_http_LOG_PHASE阶段382
10.7http框架的初始化流程382
10.8小结384
第11章http框架的执行流程385
11.1http框架执行流程概述386
11.2新连接建立时的行为387
11.3第一次可读事件的处理388
11.4接收http请求行394
11.5接收http头部398
11.6处理http请求
11.6.1ngx_http_core_generic_phase406
11.6.2ngx_http_core_rewrite_phase408
11.6.3ngx_http_core_access_phase409
11.6.4ngx_http_core_content_phase412
11.7subrequest与post请求415
11.8处理http包体417
11.8.1接收包体419
11.8.2放弃接收包体425
11.9发送http响应429
11.9.1ngx_http_send_header430
11.9.2ngx_http_output_f?ilter432
11.9.3ngx_http_writer435
11.10结束http请求437
11.10.1ngx_http_close_connection438
11.10.2ngx_http_free_request439
11.10.3ngx_http_close_request440
11.10.4ngx_http_finalize_connection441
11.10.5ngx_http_terminate_request443
11.10.6ngx_http_finalize_request443
11.11小结446
第12章upstream机制的设计与实现447
12.1upstream机制概述448
12.1.1设计目的448
12.1.2ngx_http_upstream_t数据结构的意义450
12.1.3ngx_http_upstream_conf_t配置结构体453
12.2启动upstream455
12.3与上游服务器建立连接457
12.4发送请求到上游服务器460
12.5接收上游服务器的响应头部463
12.5.1应用层协议的两段划分方式463
12.5.2处理包体的3种方式464
12.5.3接收响应头部的流程465
12.6不转发响应时的处理流程469
12.6.1input_filter方法的设计469
12.6.2默认的input_filter方法470
12.6.3接收包体的流程472
12.7以下游网速优先来转发响应473
12.7.1转发响应的包头474
12.7.2转发响应的包体477
12.8以上游网速优先来转发响应481
12.8.1ngx_event_pipe_t结构体的意义481
12.8.2转发响应的包头485
12.8.3转发响应的包体487
12.8.4ngx_event_pipe_read_upstream方法489
12.8.5ngx_event_pipe_write_to_downstream方法494
12.9结束upstream请求496
12.10小结499
第13章邮件代理模块500
13.1邮件代理服务器的功能500
13.2邮件模块的处理框架503
13.2.1一个请求的8个独立处理阶段503
13.2.2邮件类模块的定义504
13.2.3邮件框架的初始化506
13.3初始化请求506
13.3.1描述邮件请求的ngx_mail_session_t结构体506
13.3.2初始化邮件请求的流程509
13.4接收并解析客户端请求509
13.5邮件认证510
13.5.1ngx_mail_auth_http_ctx_t结构体510
13.5.2与认证服务器建立连接511
13.5.3发送请求到认证服务器513
13.5.4接收并解析响应514
13.6与上游邮件服务器间的认证交互514
13.6.1ngx_mail_proxy_ctx_t结构体516
13.6.2向上游邮件服务器发起连接516
13.6.3与邮件服务器认证交互的过程518
13.7透传上游邮件服务器与客户端间的流520
13.8小结524
第14章进程间的通信机制525
14.1概述525
14.2共享内存526
14.3原子操作530
14.3.1不支持原子库下的原子操作530
14.3.2x86架构下的原子操作531
14.3.3自旋锁533
14.4Nginx频道535
14.5信号538
14.6信号量540
14.7文件锁541
14.8互斥锁544
14.8.1文件锁实现的ngx_shmtx_t锁546
14.8.2原子变量实现的ngx_shmtx_t锁548
14.9小结553
第15章变量554
15.1使用内部变量开发模块555
15.1.1定义模块556
15.1.2定义http模块加载方式557
15.1.3解析配置中的变量558
15.1.4处理请求560
15.2内部变量工作原理561
15.2.1何时定义变量561
15.2.2相关数据结构详述564
15.2.3定义变量的方法572
15.2.4使用变量的方法572
15.2.5如何解析变量573
15.3定义内部变量576
15.4外部变量与脚本引擎577
15.4.1相关数据结构578
15.4.2编译“set”脚本581
15.4.3脚本执行流程586
15.5小结589
第16章slab共享内存590
16.1操作slab共享内存的方法590
16.2使用slab共享内存池的例子592
16.2.1共享内存中的数据结构593
16.2.2操作共享内存中的红黑树与链表595
16.2.3解析配置文件600
16.2.4定义模块603
16.3slab内存管理的实现原理605
16.3.1内存结构布局607
16.3.2分配内存流程613
16.3.3释放内存流程617
16.3.4如何使用位操作619
16.3.5slab内存池间的管理624
16.4小结624
文摘
版权页:
插图:
《深入理解Nginx:模块开发与架构解析(第2版)》由陶辉编著,机械工业出版社出版。
名人推荐
Nginx一直是高性能服务器的工程典范,它充分利用了操作系统和硬件提供的特性,涉及的知识面非常多,要领略到真正的风景需要艰难的跋涉,本书是很好的向导,一路陪伴着,适时地告诉你哪里是风景,哪里是坑,让你快乐地走完旅程。
——阿里云飞天事业部研究员 褚霸
Nginx自面世以来,就以高性能的Web服务器著称,然而由于功能强大,插件结构比较复杂,也使众多初学者很难快速入门。为了让广大读者了解Nginx的全貌并迅速投入相关的开发和运维工作中,本书作者通过图文并茂的方式由浅入深地向读者揭开了Nginx的面纱,先从Nginx服务器的配置人手,再到开发简单的HTTP Server,最后介绍Nginx的内存分配原理,既剖析了Nginx,又对如何进行高性能服务器编程进行了很好地阐述,相信对各个层次的读者都有很大的帮助,感谢陶辉!
——阿里巴巴集团核心系统部资深专家 伯瑜
Nginx作为一款面向性能设计的HTTP服务器,不但在稳定性和性能方面相当出众,而且它模块化的设计让其具有异常灵活的扩展性。本书的作者,通过大量的示例和经验,介绍了Nginx的设计思路和相关编程技巧,以及如何开发Nginx模块。看完这本书,你不但能对Nginx有一个全面了解,更重要的是可以学到Nginx的设计思路和理念,这对于任何一个想在软件设计上有所提高的程序员来说都是非常有价值的。
——酷壳网站站长 陈皓
作者简介
陶辉,毕业于西安交通大学计算机科学与技术专业,曾就职于华为中央软件部、腾讯QQ空间、思科中国CRDC等公司,目前在阿里巴巴云计算公司的飞天团队工作,研究方向为介于Iaas和Paas间的弹性计算,多年以来专注于Nginx的定制化应用,对Nginx的设计与特性有深刻认识,实战经验丰富,编写过许多优秀的Nginx模块并应用于企业级产品中,同时撰写了大量关于Nginx的技术文章。擅长Linux下高性能服务器的开发,以及分布式环境下海量数据存储的设计开发。
目录
前言
第一部分Nginx能帮我们做什么
第1章研究Nginx前的准备工作2
1.1Nginx是什么2
1.2为什么选择Nginx5
1.3准备工作7
1.3.1Linux操作系统7
1.3.2使用Nginx的必备软件7
1.3.3磁盘目录8
1.3.4Linux内核参数的优化9
1.3.5获取Nginx源码10
1.4编译安装Nginx11
1.5configure详解11
1.5.1configure的命令参数11
1.5.2configure执行流程18
1.5.3configure生成的文件21
1.6Nginx的命令行控制23
1.7小结27
第2章Nginx的配置28
2.1运行中的Nginx进程间的关系28
2.2Nginx配置的通用语法31
2.2.1块配置项31
2.2.2配置项的语法格式32
2.2.3配置项的注释33
2.2.4配置项的单位33
2.2.5在配置中使用变量33
2.3Nginx服务的基本配置34
2.3.1用于调试进程和定位问题的配置项34
2.3.2正常运行的配置项36
2.3.3优化性能的配置项37
2.3.4事件类配置项39
2.4用http核心模块配置一个静态Web服务器40
2.4.1虚拟主机与请求的分发41
2.4.2文件路径的定义45
2.4.3内存及磁盘资源的分配47
2.4.4网络连接的设置49
2.4.5MIME类型的设置52
2.4.6对客户端请求的限制53
2.4.7文件操作的优化54
2.4.8对客户端请求的特殊处理56
2.4.9ngx_http_core_module模块提供的变量57
2.5用httpproxymodule配置一个反向代理服务器59
2.5.1负载均衡的基本配置61
2.5.2反向代理的基本配置63
2.6小结66
第二部分如何编写http模块
第3章开发一个简单的http模块68
3.1如何调用http模块68
3.2准备工作70
3.2.1整型的封装71
3.2.2ngx_str_t数据结构71
3.2.3ngx_list_t数据结构71
3.2.4ngx_table_elt_t数据结构75
3.2.5ngx_buf_t数据结构75
3.2.6ngx_chain_t数据结构77
3.3如何将自己的http模块编译进Nginx77
3.3.1config文件的写法77
3.3.2利用configure脚本将定制的模块加入到Nginx中78
3.3.3直接修改Makefile文件81
3.4http模块的数据结构82
3.5定义自己的http模块86
3.6处理用户请求89
3.6.1处理方法的返回值89
3.6.2获取URI和参数92
3.6.3获取http头部94
3.6.4获取http包体97
3.7发送响应99
3.7.1发送http头部99
3.7.2将内存中的字符串作为包体发送101
3.7.3经典的“HelloWorld”示例102
3.8将磁盘文件作为包体发送103
3.8.1如何发送磁盘中的文件104
3.8.2清理文件句柄106
3.8.3支持用户多线程下载和断点续传107
3.9用C++语言编写http模块108
3.9.1编译方式的修改108
3.9.2程序中的符号转换109
3.10小结110
第4章配置、error日志和请求上下文111
4.1http配置项的使用场景111
4.2怎样使用http配置113
4.2.1分配用于保存配置参数的数据结构113
4.2.2设定配置项的解析方式115
4.2.3使用14种预设方法解析配置项121
4.2.4自定义配置项处理方法131
4.2.5合并配置项133
4.3http配置模型135
4.3.1解析http配置的流程136
4.3.2http配置模型的内存布局139
4.3.3如何合并配置项142
4.3.4预设配置项处理方法的工作原理144
4.4error日志的用法145
4.5请求的上下文149
4.5.1上下文与全异步Web服务器的关系149
4.5.2如何使用http上下文151
4.5.3http框架如何维护上下文结构152
4.6小结153
第5章访问第三方服务154
5.1upstream的使用方式155
5.1.1ngx_http_upstream_t结构体158
5.1.2设置upstream的限制性参数159
5.1.3设置需要访问的第三方服务器地址160
5.1.4设置回调方法161
5.1.5如何启动upstream机制161
5.2回调方法的执行场景162
5.2.1create_request回调方法162
5.2.2reinit_request回调方法164
5.2.3finalize_request回调方法165
5.2.4process_header回调方法165
5.2.5rewrite_redirect回调方法167
5.2.6input_filter_init与input_filter回调方法167
5.3使用upstream的示例168
5.3.1upstream的各种配置参数168
5.3.2请求上下文170
5.3.3在create_request方法中构造请求170
5.3.4在process_header方法中解析包头171
5.3.5在finalize_request方法中释放资源175
5.3.6在ngx_http_mytest_handler方法中启动upstream175
5.4subrequest的使用方式177
5.4.1配置子请求的处理方式177
5.4.2实现子请求处理完毕时的回调方法178
5.4.3处理父请求被重新激活后的回调方法179
5.4.4启动subrequest子请求179
5.5subrequest执行过程中的主要场景180
5.5.1如何启动subrequest180
5.5.2如何转发多个子请求的响应包体182
5.5.3子请求如何激活父请求185
5.6subrequest使用的例子187
5.6.1配置文件中子请求的设置187
5.6.2请求上下文188
5.6.3子请求结束时的处理方法188
5.6.4父请求的回调方法189
5.6.5启动subrequest190
5.7小结191
第6章开发一个简单的http过滤模块192
6.1过滤模块的意义192
6.2过滤模块的调用顺序193
6.2.1过滤链表是如何构成的194
6.2.2过滤链表的顺序196
6.2.3官方默认http过滤模块的功能简介197
6.3http过滤模块的开发步骤198
6.4http过滤模块的简单例子200
6.4.1如何编写config文件201
6.4.2配置项和上下文201
6.4.3定义http过滤模块203
6.4.4初始化http过滤模块204
6.4.5处理请求中的http头部204
6.4.6处理请求中的http包体206
6.5小结206
第7章Nginx提供的高级数据结构207
7.1Nginx提供的高级数据结构概述207
7.2ngx_queue_t双向链表209
7.2.1为什么设计ngx_queue_t双向链表209
7.2.2双向链表的使用方法209
7.2.3使用双向链表排序的例子212
7.2.4双向链表是如何实现的213
7.3ngx_array_t动态数组215
7.3.1为什么设计ngx_array_t动态数组215
7.3.2动态数组的使用方法215
7.3.3使用动态数组的例子217
7.3.4动态数组的扩容方式218
7.4ngx_list_t单向链表219
7.5ngx_rbtree_t红黑树219
7.5.1为什么设计ngx_rbtree_t红黑树219
7.5.2红黑树的特性220
7.5.3红黑树的使用方法222
7.5.4使用红黑树的简单例子225
7.5.5如何自定义添加成员方法226
7.6ngx_radix_tree_t基数树228
7.6.1ngx_radix_tree_t基数树的原理228
7.6.2基数树的使用方法230
7.6.3使用基数树的例子231
7.7支持通配符的散列表232
7.7.1ngx_hash_t基本散列表232
7.7.2支持通配符的散列表235
7.7.3带通配符散列表的使用例子241
7.8小结245
第三部分深入Nginx
第8章Nginx基础架构248
8.1Web服务器设计中的关键约束249
8.2Nginx的架构设计251
8.2.1优秀的模块化设计251
8.2.2事件驱动架构254
8.2.3请求的多阶段异步处理256
8.2.4管理进程、多工作进程设计259
8.2.5平台无关的代码实现259
8.2.6内存池的设计259
8.2.7使用统一管道过滤器模式的http过滤模块260
8.2.8其他一些用户模块260
8.3Nginx框架中的核心结构体ngx_cycle_t260
8.3.1ngx_listening_t结构体261
8.3.2ngx_cycle_t结构体262
8.3.3ngx_cycle_t支持的方法264
8.4Nginx启动时框架的处理流程266
8.5worker进程是如何工作的269
8.6master进程是如何工作的271
8.7ngx_pool_t内存池276
8.8小结284
第9章事件模块285
9.1事件处理框架概述286
9.2Nginx事件的定义288
9.3Nginx连接的定义291
9.3.1被动连接292
9.3.2主动连接295
9.3.3ngx_connection_t连接池296
9.4ngx_events_module核心模块297
9.4.1如何管理所有事件模块的配置项299
9.4.2管理事件模块300
9.5ngx_event_core_module事件模块302
9.6epoll事件驱动模块308
9.6.1epoll的原理和用法308
9.6.2如何使用epoll310
9.6.3ngx_epoll_module模块的实现312
9.7定时器事件320
9.7.1缓存时间的管理320
9.7.2缓存时间的精度323
9.7.3定时器的实现323
9.8事件驱动框架的处理流程324
9.8.1如何建立新连接325
9.8.2如何解决“惊群”问题327
9.8.3如何实现负载均衡329
9.8.4post事件队列330
9.8.5ngx_process_events_and_timers流程331
9.9文件的异步I/O334
9.9.1Linux内核提供的文件异步I/O335
9.9.2ngx_epoll_module模块中实现的针对文件的异步I/O337
9.10TCP协议与Nginx342
9.11小结347
第10章http框架的初始化348
10.1http框架概述349
10.2管理http模块的配置项352
10.2.1管理main级别下的配置项353
10.2.2管理server级别下的配置项355
10.2.3管理location级别下的配置项358
10.2.4不同级别配置项的合并364
10.3监听端口的管理367
10.4server的快速检索370
10.5location的快速检索370
10.6http请求的11个处理阶段372
10.6.1http处理阶段的普适规则374
10.6.2NGX_http_POST_READ_PHASE阶段375
10.6.3NGX_http_SERVER_REWRITE_PHASE阶段378
10.6.4NGX_http_FIND_CONFIG_PHASE阶段378
10.6.5NGX_http_REWRITE_PHASE阶段378
10.6.6NGX_http_POST_REWRITE_PHASE阶段379
10.6.7NGX_http_PREACCESS_PHASE阶段379
10.6.8NGX_http_ACCESS_PHASE阶段379
10.6.9NGX_http_POST_ACCESS_PHASE阶段380
10.6.10NGX_http_TRY_FILES_PHASE阶段380
10.6.11NGX_http_CONTENT_PHASE阶段380
10.6.12NGX_http_LOG_PHASE阶段382
10.7http框架的初始化流程382
10.8小结384
第11章http框架的执行流程385
11.1http框架执行流程概述386
11.2新连接建立时的行为387
11.3第一次可读事件的处理388
11.4接收http请求行394
11.5接收http头部398
11.6处理http请求
11.6.1ngx_http_core_generic_phase406
11.6.2ngx_http_core_rewrite_phase408
11.6.3ngx_http_core_access_phase409
11.6.4ngx_http_core_content_phase412
11.7subrequest与post请求415
11.8处理http包体417
11.8.1接收包体419
11.8.2放弃接收包体425
11.9发送http响应429
11.9.1ngx_http_send_header430
11.9.2ngx_http_output_f?ilter432
11.9.3ngx_http_writer435
11.10结束http请求437
11.10.1ngx_http_close_connection438
11.10.2ngx_http_free_request439
11.10.3ngx_http_close_request440
11.10.4ngx_http_finalize_connection441
11.10.5ngx_http_terminate_request443
11.10.6ngx_http_finalize_request443
11.11小结446
第12章upstream机制的设计与实现447
12.1upstream机制概述448
12.1.1设计目的448
12.1.2ngx_http_upstream_t数据结构的意义450
12.1.3ngx_http_upstream_conf_t配置结构体453
12.2启动upstream455
12.3与上游服务器建立连接457
12.4发送请求到上游服务器460
12.5接收上游服务器的响应头部463
12.5.1应用层协议的两段划分方式463
12.5.2处理包体的3种方式464
12.5.3接收响应头部的流程465
12.6不转发响应时的处理流程469
12.6.1input_filter方法的设计469
12.6.2默认的input_filter方法470
12.6.3接收包体的流程472
12.7以下游网速优先来转发响应473
12.7.1转发响应的包头474
12.7.2转发响应的包体477
12.8以上游网速优先来转发响应481
12.8.1ngx_event_pipe_t结构体的意义481
12.8.2转发响应的包头485
12.8.3转发响应的包体487
12.8.4ngx_event_pipe_read_upstream方法489
12.8.5ngx_event_pipe_write_to_downstream方法494
12.9结束upstream请求496
12.10小结499
第13章邮件代理模块500
13.1邮件代理服务器的功能500
13.2邮件模块的处理框架503
13.2.1一个请求的8个独立处理阶段503
13.2.2邮件类模块的定义504
13.2.3邮件框架的初始化506
13.3初始化请求506
13.3.1描述邮件请求的ngx_mail_session_t结构体506
13.3.2初始化邮件请求的流程509
13.4接收并解析客户端请求509
13.5邮件认证510
13.5.1ngx_mail_auth_http_ctx_t结构体510
13.5.2与认证服务器建立连接511
13.5.3发送请求到认证服务器513
13.5.4接收并解析响应514
13.6与上游邮件服务器间的认证交互514
13.6.1ngx_mail_proxy_ctx_t结构体516
13.6.2向上游邮件服务器发起连接516
13.6.3与邮件服务器认证交互的过程518
13.7透传上游邮件服务器与客户端间的流520
13.8小结524
第14章进程间的通信机制525
14.1概述525
14.2共享内存526
14.3原子操作530
14.3.1不支持原子库下的原子操作530
14.3.2x86架构下的原子操作531
14.3.3自旋锁533
14.4Nginx频道535
14.5信号538
14.6信号量540
14.7文件锁541
14.8互斥锁544
14.8.1文件锁实现的ngx_shmtx_t锁546
14.8.2原子变量实现的ngx_shmtx_t锁548
14.9小结553
第15章变量554
15.1使用内部变量开发模块555
15.1.1定义模块556
15.1.2定义http模块加载方式557
15.1.3解析配置中的变量558
15.1.4处理请求560
15.2内部变量工作原理561
15.2.1何时定义变量561
15.2.2相关数据结构详述564
15.2.3定义变量的方法572
15.2.4使用变量的方法572
15.2.5如何解析变量573
15.3定义内部变量576
15.4外部变量与脚本引擎577
15.4.1相关数据结构578
15.4.2编译“set”脚本581
15.4.3脚本执行流程586
15.5小结589
第16章slab共享内存590
16.1操作slab共享内存的方法590
16.2使用slab共享内存池的例子592
16.2.1共享内存中的数据结构593
16.2.2操作共享内存中的红黑树与链表595
16.2.3解析配置文件600
16.2.4定义模块603
16.3slab内存管理的实现原理605
16.3.1内存结构布局607
16.3.2分配内存流程613
16.3.3释放内存流程617
16.3.4如何使用位操作619
16.3.5slab内存池间的管理624
16.4小结624
文摘
版权页:
插图:
ISBN | 7111526252,9787111526254 |
---|---|
出版社 | 机械工业出版社 |
作者 | 陶辉 |
尺寸 | 16 |