《Nginx开发从入门到精通》,


缘起

nginx由于出色的性能,在世界范围内受到了越来越多人的关注,在淘宝内部它更是被广泛的使用,众多的开发以及运维同学都迫切的想要了解nginx模块的开发以及它的内部原理,但是国内却没有一本关于这方面的书,源于此我们决定自己来写一本。本书的作者为淘宝核心系统服务器平台组的成员,本书写作的思路是从模块开发逐渐过渡到nginx原理剖析。书籍的内容会定期在这里更新,欢迎大家提出宝贵意见,不管是本书的内容问题,还是字词错误,都欢迎大家提交issue(章节标题的左侧有评注按钮),我们会及时的跟进。

更新历史

日期描述
2012/03/01 创建目录大纲
2012/03/28 增加了样章
2012/05/25 更新样章
2012/06/08 增加第5章
2012/06/11 增加第4章
2012/06/26 增加第6章(event module)
2012/06/27 更新第5章部分内容
2012/07/04 更新第6章event module部分内容
2012/07/12 增加第12章(请求头读取,subrequest解析)
2012/08/14 增加第2章(nginx基础架构及基础概念)
2012/08/14 增加第2章(ngx_str_t数据结构介绍)
2012/08/17 增加第7章(模块开发高级篇之变量)
2012/08/25 增加第11章(nginx的启动阶段部分内容)
2012/09/26 增加第2章(ngx_array_t,ngx_hash_t及ngx_pool_t介绍)
2012/10/08 增加第11章(配置解析综述)
2012/10/12 增加第2章(ngx_hash_wildcard_t,ngx_hash_combined_t及ngx_hash_keys_arrays_t介绍)
2012/10/21 增加第2章(ngx_chain_t,ngx_list_t及ngx_buf_t介绍)
2012/11/09 增加第12章(请求体的读取和丢弃解析)
2012/11/24 更新第2章(ngx_buf_t的部分字段以及其他一些书写错误和表达)
2012/12/18 更新第11章(解析http块)
2012/12/10 增加第3章的内容
2012/12/28 补充和完善了第3章的内容
2013/01/25 增加了第2章(nginx的配置系统)
2013/02/18 增加了第2章(nginx的模块化体系结构, nginx的请求处理)
2013/03/05 增加了第12章部分内容(多阶段请求处理)
2013/03/08 完成第11章第1节(配置解析综述、ngx_http_block)

版权申明

本书的著作权归作者淘宝核心系统服务器平台组成员所有。你可以:

  • 下载、保存以及打印本书
  • 网络链接、转载本书的部分或者全部内容,但是必须在明显处提供读者访问本书发布网站的链接
  • 在你的程序中任意使用本书所附的程序代码,但是由本书的程序所引起的任何问题,作者不承担任何责任

你不可以:

  • 以任何形式出售本书的电子版或者打印版
  • 擅自印刷、出版本书
  • 以纸媒出版为目的,改写、改编以及摘抄本书的内容

项目

项目地址:https://github.com/taobao/nginx-book

在线阅读版本:http://tengine.taobao.org/book/index.html

目录

  • 上篇:nginx模块开发篇
    • 背景介绍
      • nginx历史
      • 使用简介
      • nginx特点介绍
    • nginx平台初探(30%)
      • 初探nginx架构(100%)
      • nginx基础概念(100%)
        • connection
        • request
      • 基本数据结构(99%)
        • ngx_str_t(100%)
        • ngx_pool_t(100%)
        • ngx_array_t(100%)
        • ngx_hash_t(100%)
        • ngx_hash_wildcard_t(100%)
        • ngx_hash_combined_t(100%)
        • ngx_hash_keys_arrays_t(100%)
        • ngx_chain_t(100%)
        • ngx_buf_t(99%)
        • ngx_list_t(100%)
      • nginx的配置系统(100%)
        • 指令概述
        • 指令参数
        • 指令上下文
      • nginx的模块化体系结构
      • 模块概述
        • 模块的分类
      • nginx的请求处理
        • 请求的处理流程
    • handler模块(100%)
      • handler模块简介
      • 模块的基本结构
        • 模块配置结构
        • 模块配置指令
        • 模块上下文结构
        • 模块的定义
      • handler模块的基本结构
      • handler模块的挂载
        • 按处理阶段挂载
        • 按需挂载
      • handler的编写步骤
      • hello handler 模块
      • handler模块的编译和使用
        • config文件的编写
        • 编译
        • 使用
      • 部分handler模块的分析
        • http access module
        • http static module
        • http log module
    • 过滤模块 (90%)
      • 过滤模块简介 (90%)
        • 执行时间和内容 (90%)
        • 执行顺序 (90%)
        • 模块编译 (90%)
      • 过滤模块的分析 (90%)
        • 相关结构体 (90%)
        • 响应头过滤函数 (90%)
        • 响应体过滤函数 (90%)
    • upstream模块
      • upstream模块 (100%)
        • upstream模块接口
        • memcached模块分析
        • 本节回顾
      • 负载均衡模块 (100%)
        • 配置
        • 指令
        • 钩子
        • 初始化配置
        • 初始化请求
        • peer.get和peer.free回调函数
        • 本节回顾
    • 其他模块 (40%)
      • core模块 (40%)
        • Nginx的启动模块 (40%)
      • event模块 (40%)
        • event的类型和功能 (40%)
        • accept锁 (40%)
        • 定时器 (40%)
      • mail模块
        • mail模块的实现
        • mail模块的功能
    • 模块开发高级篇(30%)
      • 变量(80%)
        • 综述
        • 创建变量
        • 使用变量
      • upstream
        • 使用subrequest访问upstream
        • 超越upstream
      • 使用lua模块
  • 下篇:nginx原理解析篇
    • 高性能服务器设计
      • c10k问题
      • 高性能服务器编写的关键原则
      • 事件驱动的核心引擎
      • 定时器管理
    • nginx架构详解
      • nginx的源码目录结构
      • nginx的configure原理
        • auto脚本
        • 模块编译顺序
      • nginx的事件机制
        • event框架及非阻塞模型
        • 定时器实现
        • 信号处理
        • 惊群问题
      • nginx的进程机制
        • master进程
        • worker进程
        • 进程间通讯
    • nginx基础设施
      • 内存池
      • 共享内存
        • slab算法
      • buffer管理
        • buffer重用机制
        • buffer防拷贝机制
      • chain管理
        • chain重用机制
      • aio原理
      • 锁实现
      • 基本数据结构
      • 时间缓存
      • 文件缓存
      • log机制
    • nginx的启动阶段 (30%)
      • 概述 (100%)
      • 共有流程 (100%)
        • 配置解析接口 (100%)
      • 配置解析
        • 通用过程 (100%)
        • http的解析
        • server的管理
        • location的管理
      • 模块初始化
      • 热代码部署
        • reload过程解析
        • upgrade过程解析
    • nginx的请求处理阶段 (30%)
      • 接收请求流程 (99%)
        • http请求格式简介 (99%)
        • 请求头读取 (99%)
        • 请求体读取(100%)
      • 多阶段处理请求
        • 多阶段执行链
        • POST_READ阶段
        • find-config阶段
        • rewrite阶段
        • post-rewrite阶段
        • access阶段
        • post-access阶段
        • content阶段
        • log阶段
      • 返回响应数据
        • header filter分析
        • body filter分析
        • finalize_request函数分析
        • 特殊响应
        • chunked响应体
      • pipeline请求
      • keepalive请求
      • subrequest原理解析 (99%)
    • nginx的upstream原理解析
      • 无缓冲的处理流程
      • 带缓冲的处理流程
      • subrequest访问upstream的处理流程
      • 负载均衡算法
        • round-robin算法
        • 基于ip的hash算法
      • upstream缓存机制
      • 常用upstream模块分析
        • proxy模块
        • fastcgi模块
    • nginx的script处理
      • 正则表达式
      • 变量
      • 复杂变量
      • if的处理
  • 附录A 编码风格 (100%)
    • Nginx代码风格图示 (100%)
  • 附录B 常用API
    • B.1 字符串操作
    • B.2 读取请求体
    • B.3 操作请求头
    • B.4 取参数
    • B.5 URI处理
    • B.6 buffer操作
    • B.7 变量操作
    • B.8 日志输出
    • B.9 配置解析接口
    • B.10 文件操作
    • B.11 锁操作
  • 附录C 模块编译,调试与测试
    • C.1 添加第3方库
    • C.2 添加额外编译,链接选项
    • C.3 debug point
    • C.4 使用gdb
    • C.5 调试日志
    • C.6 单元测试
    • C.7 功能测试
    • C.8 性能测试
 


相关内容

    暂无相关文章