语法

  1. #普通匹配:location /static {}
  2. #正则匹配:
  3. location ~ /static {} #区分大小写
  4. location ~* /static {} #不区分大小写
  5. location ^~ /static {} #开头匹配
  6. location = / {} #全等匹配
  7. #优先级:(location =) > (location 完整路径) >(location ^~ 路径) >(location ~*|~ 正则) >(location 路径)
  8. #优先级相同,但匹配到多个的规则:谁在前就返回谁

  1. location = / {
  2.  #只匹配/查询
  3. }
  4. location / {
  5. #匹配任何查询,所有请求都是以/开头。但是正则表达式规则和长的块规则将被优先匹配和查询;
  6. }
  7. location ^~ /images/ {
  8. # 匹配任何已 /images/ 开头的任何查询并且停止搜索。任何正则表达式将不会被测试。
  9. }
  10. location ~* \.(gif|jpg|png)${
  11. #匹配任何以gif、jpg、png结尾的请求。然后所有/images/目录的请求将使用第三个
  12. }
  13. 例子请求:
  14. / configuration A
  15. /documents/document.html configuration B
  16. /images/1.gif configuration C
  17. /documents/1.jpg configuration D

当匹配成功后location中可以使用rewrite进行路由重写;
首先需要了解nginx 的全局变量

全局变量

  1. $args #请求中的参数值
  2. $query_string #同 $args
  3. $arg_NAME #GET请求中NAME的值
  4. $is_args #如果请求中有参数,值为"?",否则为空字符串
  5. $uri #请求中的当前URI(不包含主机名,不带请求参数),如"/foo/bar.html"
  6. $document_uri #同 $uri
  7. $document_root #当前请求的文档根目录或别名
  8. $host #优先级:HTTP请求行的主机名>"HOST"请求头字段>符合请求的服务器名.请求中的主机头字段,如果请求中的主机头不可用,则为服务器处理请求的服务器名称
  9. $hostname #主机名
  10. $https #如果开启了SSL安全模式,值为"on",否则为空字符串。
  11. $binary_remote_addr #客户端地址的二进制形式,固定长度为4个字节
  12. $body_bytes_sent #传输给客户端的字节数,响应头不计算在内;这个变量和Apache的mod_log_config模块中的"%B"参数保持兼容
  13. $bytes_sent #传输给客户端的字节数
  14. $connection #TCP连接的序列号
  15. $connection_requests #TCP连接当前的请求数量
  16. $content_length #"Content-Length" 请求头字段
  17. $content_type #"Content-Type" 请求头字段
  18. $cookie_name #cookie名称
  19. $limit_rate #用于设置响应的速度限制
  20. $msec #当前的Unix时间戳
  21. $nginx_version #nginx版本
  22. $pid #工作进程的PID
  23. $pipe #如果请求来自管道通信,值为"p",否则为"."
  24. $proxy_protocol_addr #获取代理访问服务器的客户端地址,如果是直接访问,该值为空字符串
  25. $realpath_root #当前请求的文档根目录或别名的真实路径,会将所有符号连接转换为真实路径
  26. $remote_addr #客户端地址
  27. $remote_port #客户端端口
  28. $remote_user #用于HTTP基础认证服务的用户名
  29. $request #代表客户端的请求地址
  30. $request_body #客户端的请求主体:此变量可在location中使用,将请求主体通过proxy_pass,fastcgi_pass,uwsgi_pass和scgi_pass传递给下一级的代理服务器
  31. $request_body_file #将客户端请求主体保存在临时文件中。文件处理结束后,此文件需删除。如果需要之一开启此功能,需要设置client_body_in_file_only。如果将次文件传 递给后端的代理服务器,需要禁用request body,即设置proxy_pass_request_body off,fastcgi_pass_request_body off,uwsgi_pass_request_body off,or scgi_pass_request_body off
  32. $request_completion #如果请求成功,值为"OK",如果请求未完成或者请求不是一个范围请求的最后一部分,则为空
  33. $request_filename #当前连接请求的文件路径,由root或alias指令与URI请求生成
  34. $request_length #请求的长度 (包括请求的地址,http请求头和请求主体)
  35. $request_method #HTTP请求方法,通常为"GET"或"POST"
  36. $request_time #处理客户端请求使用的时间,单位为秒,精度毫秒; 从读入客户端的第一个字节开始,直到把最后一个字符发送给客户端后进行日志写入为止。
  37. $request_uri #这个变量等于包含一些客户端请求参数的原始URI,它无法修改,请查看$uri更改或重写URI,不包含主机名,例如:"/cnphp/test.php?arg=freemouse"
  38. $scheme #请求使用的Web协议,"http" 或 "https"
  39. $server_addr #服务器端地址,需要注意的是:为了避免访问linux系统内核,应将ip地址提前设置在配置文件中
  40. $server_name #服务器名
  41. $server_port #服务器端口
  42. $server_protocol #服务器的HTTP版本,通常为 "HTTP/1.0" 或 "HTTP/1.1"
  43. $status #HTTP响应代码
  44. $time_iso8601 #服务器时间的ISO 8610格式
  45. $time_local #服务器时间(LOG Format 格式)
  46. $cookie_NAME #客户端请求Header头中的cookie变量,前缀"$cookie_"加上cookie名称的变量,该变量的值即为cookie名称的值
  47. $http_NAME #匹配任意请求头字段;变量名中的后半部分NAME可以替换成任意请求头字段,如在配置文件中需要获取http请求头:"Accept-Language",$http_accept_language即可
  48. $http_cookie        #请求的所有cookie
  49. $http_host #请求地址,即浏览器中你输入的地址(IP或域名)
  50. $http_referer #url跳转来源,用来记录从那个页面链接访问过来的
  51. $http_user_agent #用户终端浏览器等信息
  52. $http_x_forwarded_for #客户端的IP和代理服务器的IP,以逗号隔开;可伪造
  53. $http_x_forwarded_proto #请求的协议

判断

  1. if ($http_user_agent ~ MSIE) { #如果客户端是微软的IE浏览器,就将请求rewrite到msie目录下。
  2. rewrite ^(.*)$ /msie/$1 break;
  3. }
  4. if ($http_cookie ~* "user_id") { # 如果cookie匹配正则失败,认为没登陆,跳转到登陆页面
  5. rewrite ^ http://example.com/login;
  6. }
  7. if ($request_method = POST) { #如果提交方法为POST,则返回状态405(Method not allowed)。
  8. return 405;
  9. }
  10. if ($slow) { #限速,$slow可以通过 set 指令设置
  11. limit_rate 10k;
  12. }
  13. if (!-f $request_filename){ #如果请求的文件名不存在,则反向代理到localhost 。这里的break也是停止rewrite检查
  14. break;
  15. proxy_pass http://127.0.0.1;
  16. }
  17. if ($args ~ post=140){ #如果query string中包含"post=140",永久重定向到example.com
  18. rewrite ^ http://example.com/permanent;
  19. }

root、alias区别

root

  • 语法:root path
  • 默认值:root html
  • 配置段:http、server、location、if

    alias

  • 语法:alias path

  • 配置段:location

    区别:

  • root与alias主要区别在于nginx如何解释location后面的uri,这会使两者分别以不同的方式将请求映射到服务器文件上。

  • root的处理结果是:root路径+location路径
  • alias的处理结果是:使用alias路径替换location路径
  • alias是一个目录别名的定义
  • root则是最上层目录的定义 ```nginx location /t/ { root /www/; } URI是/t/a.html时,返回服务器上的/www/t/a.html的文件

location ^~ /t/ { alias /www/; } URI是/t/a.html时,返回服务器上的/www/a.html的文件,会将/t/舍弃

  1. 例如我有一张图片:www.micserver.cn/static/test.jpg<br />它在服务器的路径是:/home/jw/static/
  2. ```nginx
  3. #root的配置:
  4. location /static/ {
  5. root /home/jw/;
  6. }
  7. #alias的配置:
  8. location /static/ {
  9. alias /home/jw/static/;
  10. }
  11. #对于alias的location是可以随便取的
  12. location ~* \.(gif|jpg|png)${
  13. alias /home/jw/static/; #这样也ok
  14. }