Nginx核心知识100讲学习笔记(陶辉)详解HTTP模块(详解11阶段)
一、server_name指令
1、指令后可跟多个域名。第一个是主域名
Syntax server_name_in_redirect on | off; Default server_name_in_redirect off; Context http, server, location
server_name_in_redirect on
server { server_name primary.luoahong.tech second.luoahong.tech; server_name_in_redirect on; return 302 /redirect; }
测试:
[root@ceph-client vhost]# curl second.luoahong.tech -I HTTP/1.1 302 Moved Temporarily Server: openresty/1.13.6.2 Date: Wed, 26 Aug 2020 01:26:22 GMT Content-Type: text/html Content-Length: 167 Location: http://primary.luoahong.tech/redirect Connection: keep-alive
server_name_in_redirect off
[root@ceph-client conf]# nginx -s reload [root@ceph-client vhost]# curl second.luoahong.tech -I HTTP/1.1 302 Moved Temporarily Server: openresty/1.13.6.2 Date: Wed, 26 Aug 2020 01:26:09 GMT Content-Type: text/html Content-Length: 167 Location: http://second.luoahong.tech/redirect Connection: keep-alive
2、*泛域名:仅支持在最前或者最后
server_name *.luoahong.com
3、正则表达式:加~前缀
server_name www.luoahong.com ~^www\d+\.luoahong\.com$;
4、用正则表达式创建变量:
例如:
server { server_name ~^(www\.)?(.+)$; location / { root /sites/$2; } }
用小括号()
server { server_name ~^(www\.)?(?<domain>.+)$; location / { root /sites/$domain; } }
5、其他
.luoahong.tech可以匹配 luoahong.tech *.luoahong.tech _匹配所有 "" 匹配没有传递Host头部
6、server匹配顺序
1、精确匹配
2、*在前的泛域名
3、*在后的泛域名
4、按文件中的顺序匹配正则表达式域名
5、default server
第1个
listen指定default
二、http请求处理图解
三、http请求的11个阶段表格
Nginx的模块化设计使得每一个HTTP模块可以仅专注于完成一个独立的、简单的功能,而一个请求的完整处理过程可以由无数个HTTP模块共同合作完成。这种设计有非常好的简单性、可测试性、可扩展性,然而,当多个http模块流水式地处理同一个请求时,单一的处理顺序是无法满足灵活性需求的,每一个正在处理的HTTP模块很难灵活、有效地指定下一个HTTP处理模块是哪一个。
因此,HTTP框架依据常见的处理流程将处理阶段划分为11个阶段,其中每个处理阶段都可以由任意多个HTTP模块流水式地处理请求。
typedef enum { //在接收到完整的HTTP头部后处理的HTTP阶段 NGX_HTTP_POST_READ_PHASE = 0, //在请求的URI与location表达式匹配前,修改请求的URI(重定向),是一个独立的HTTP阶段 NGX_HTTP_SERVER_REWRITE_PHASE, //根据请求的URI寻找匹配的location表达式,这个阶段只能由 NGX_HTTP_FIND_CONFIG_PHASE, //在NGX_HTTP_FIND_CONFIG_PHASE阶段寻找到匹配的location之后再修改请求的URI NGX_HTTP_REWRITE_PHASE, //这一阶段是用于在rewrite重写URL后,防止错误的nginx.conf配置导致死循环(递归地修改URI) NGX_HTTP_POST_REWRITE_PHASE, //表示在处理NGX_HTTP_ACCESS_PHASE阶段觉得请求的访问权限前,HTTP模块可以介入的处理阶段 NGX_HTTP_PREACCESS_PHASE, //这个阶段用于让HTTP模块判断是否允许这个请求访问nginx服务器 NGX_HTTP_ACCESS_PHASE, //在NGX_HTTP_ACCESS_PHASE阶段中,当HTTP模块的handler处理函数返回不允许访问的错误码时(NGX_HTTP_FORBIDDEN或者NGX_HTTP_UNAUHORIZED),这里将负责向用户发送拒绝服务的错误响应。 NGX_HTTP_POST_ACCESS_PHASE, //此阶段专门为try_files配置项设立,当HTTP请求访问静态文件资源时,try_files配置项可以使这个配置项顺序地访问多个静态文件资源 NGX_HTTP_TRY_FILES_PHASE, //用于处理HTTP请求内容的阶段,这是大部分HTTP模块最愿意介入的阶段 NGX_HTTP_CONTENT_PHASE, //处理完请求后记录日志的阶段,ngx_http_log_module模块就在这个阶段中加入了一个handler处理方法,使得每个HTTP请求处理完毕后会记录access_log访问日志 NGX_HTTP_LOG_PHASE } ngx_http_phases; 这11个阶段有些是必备的,有些是可选的,也可以有多个HTTP模块同时介入同一阶段 HTTP阶段的定义,包括checker检查方法和handler处理方法,如下所示: typedef structngx_http_phase_handler_s ngx_http_phase_handler_t; /*一个HTTP处理阶段中的checker检查方法,仅可以由HTTP框架实现,以此控制HTTP请求的处理流程*/ typedef ngx_int_t(*ngx_http_phase_handler_pt)(ngx_http_request_t *r, ngx_http_phase_handler_t*ph); /*由HTTP模块实现的handler处理方法*/ typedef ngx_int_t(*ngx_http_handler_pt)(ngx_http_request_t *r); struct ngx_http_phase_handler_s { /*在处理到某一个HTTP阶段时,HTTP框架将会在checker方法已实现的前提下首先调用checker方法来处理请求, 而不会直接调用任何阶段中的hanlder方法,只有在checker方法中才会去调用handler方法,因此,事实上所有 的checker方法都是由框架中的ngx_http_core_module模块实现的,且普通模块无法重定义checker方法*/ ngx_http_phase_handler_pt checker; /*除ngx_http_core_module模块以外的HTTP模块,只能通过定义handler方法才能介入某一个HTTP处理阶段以处理请求*/ ngx_http_handler_pt handler; /*将要处理的下一个HTTP处理阶段的序号 next的设计使得处理阶段不必按顺序依次执行,既可以向后跳跃数个阶段继续执行,也可以跳跃到之前的某个阶段重新 执行,通常,next表示下一个处理阶段中的第1个ngx_http_phase_handler_t处理方法*/ ngx_uint_t next; };
使用的模块 | 备注 | |
---|---|---|
POST_READ | realip | 刚读完http请求头、没有经过任何加工过、我想获取到一些原始的值 |
SERVER_REWRITE | rewrite | 它和下面REWRITE的只有一个模块 |
FIND_CONFIG | 这个只有nginx框架会做 | 所以没有任何的模块、就是在做location的一个匹配 |
REWRITE | rewrite | 一般第三方模块没有一个处理REWRITE |
POST_REWRITE | 刚刚REWRITE之后要做的一些事情 | |
PREACCESS | limt_conn, limit_req | 在access之前要不要做一些工作、 限制速度、 限制连接数 |
ACCESS | auth_basic| access|auth_request | 确认访问权限的 能不能访问|根据访问的ip|根据第三方的服务 |
POST_ACCESS | ||
PRECONFTENT | try_files mirrors | 处理CONTENT之前 会把这个服务发送给第三方服务、一个请求产生多个请求值 |
CONTENT | index| autoindex|concat | 反向代理 |
LOG | access_log |
四、11个阶段的处理顺序
1、通过编译后的配置文件看处理顺序
vim /usr/local/src/openresty-1.13.6.2/bundle/nginx-1.13.6/auto/modules .......... ngx_module_order="ngx_http_static_module \ ngx_http_gzip_static_module \ ngx_http_dav_module \ ngx_http_autoindex_module \ ngx_http_index_module \ ngx_http_random_index_module \ ngx_http_access_module \ ngx_http_realip_module \ ngx_http_write_filter_module \ ngx_http_header_filter_module \ ngx_http_chunked_filter_module \ ngx_http_v2_filter_module \ ngx_http_range_header_filter_module \ ngx_http_gzip_filter_module \ ngx_http_postpone_filter_module \ ngx_http_ssi_filter_module \ ngx_http_charset_filter_module \ ngx_http_xslt_filter_module \ ngx_http_image_filter_module \ ngx_http_sub_filter_module \ ngx_http_addition_filter_module \ ngx_http_gunzip_filter_module \ ngx_http_userid_filter_module \ ngx_http_headers_filter_module \ ngx_http_copy_filter_module \ ngx_http_range_body_filter_module \ ngx_http_not_modified_filter_module \ ngx_http_slice_filter_module" ..........
2、postread阶段
3、preaccess阶段
4、access阶段
5、precontent阶段
6、content阶段
7、 log阶段
作者:罗阿红
出处:http://www.cnblogs.com/luoahong/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。