1. nginx 11 个处理阶段nginx
nginx实际把请求处理流程划分为了11个阶段,这样划分的缘由是将请求的执行逻辑细分,各阶段按照处理时机定义了清晰的执行语义,开发者能够很容易分辨本身须要开发的模块应该定义在什么阶段,其定义在http/ngx_http_core_module.h中有定义:缓存
NGX_HTTP_POST_READ_PHASE:
接收完请求头以后的第一个阶段,它位于uri重写以前,实际上不多有模块会注册在该阶段,默认的状况下,该阶段被跳过并发
NGX_HTTP_SERVER_REWRITE_PHASE:
server级别的uri重写阶段,也就是该阶段执行处于server块内,location块外的重写指令,在读取请求头的过程当中nginx会根据host及端口找到对应的虚拟主机配置异步
NGX_HTTP_FIND_CONFIG_PHASE:
寻找location配置阶段,该阶段使用重写以后的uri来查找对应的location,值得注意的是该阶段可能会被执行屡次,由于也可能有location级别的重写指令lua
NGX_HTTP_REWRITE_PHASE:
location级别的uri重写阶段,该阶段执行location基本的重写指令,也可能会被执行屡次代理
NGX_HTTP_POST_REWRITE_PHASE:
location级别重写的后一阶段,用来检查上阶段是否有uri重写,并根据结果跳转到合适的阶段日志
NGX_HTTP_PREACCESS_PHASE:
访问权限控制的前一阶段,该阶段在权限控制阶段以前,通常也用于访问控制,好比限制访问频率,连接数等server
NGX_HTTP_ACCESS_PHASE:
访问权限控制阶段,好比基于ip黑白名单的权限控制,基于用户名密码的权限控制等接口
NGX_HTTP_POST_ACCESS_PHASE:
问权限控制的后一阶段,该阶段根据权限控制阶段的执行结果进行相应处理ip
NGX_HTTP_TRY_FILES_PHASE:
try_files指令的处理阶段,若是没有配置try_files指令,则该阶段被跳过
NGX_HTTP_CONTENT_PHASE:
内容生成阶段,该阶段产生响应,并发送到客户端
NGX_HTTP_LOG_PHASE:
日志记录阶段,该阶段记录访问日志
2. nginx lua 8个处理阶段
init_by_lua httpset_by_lua server, server if, location, location ifrewrite_by_lua http, server, location, location ifaccess_by_lua http, server, location, location ifcontent_by_lua location, location ifheader_filter_by_lua http, server, location, location ifbody_filter_by_lua http, server, location, location iflog_by_lua http, server, location, location if{ set_by_lua: 流程分支处理判断变量初始化 rewrite_by_lua: 转发、重定向、缓存等功能(例如特定请求代理到外网) access_by_lua: IP准入、接口权限等状况集中处理(例如配合iptable完成简单防火墙) content_by_lua: 内容生成 header_filter_by_lua: 应答HTTP过滤处理(例如添加头部信息) body_filter_by_lua: 应答BODY过滤处理(例如完成应答内容统一成大写) log_by_lua: 会话完成后本地异步完成日志记录(日志能够记录在本地,还能够同步到其余机器)}