设为首页 收藏本站
查看: 1148|回复: 0

[经验分享] Nginx的location用法备忘

[复制链接]

尚未签到

发表于 2018-11-16 11:54:08 | 显示全部楼层 |阅读模式
  转载请注明出处:【Nginx的location用法备忘】http://www.holmesian.org/nginx_location
  Nginx的配置文件相当的漂亮,配合适当的缩进和约定的格式看起来跟漂亮的代码一样。
  Nginx中最基本也是最实用的一个命令就是location了,location必须放在server中,现在摘录一些相关的文档以备忘。
  基本语法
  location [=|~|~*|^~] /uri/ { … }
  = 严格匹配。如果这个查询匹配,那么将停止搜索并立即处理此请求。
  ~ 为区分大小写匹配
  ~* 为不区分大小写匹配
  !~和!~*分别为区分大小写不匹配及不区分大小写不匹配
  ^~ 如果把这个前缀用于一个常规字符串,那么告诉nginx 如果路径匹配那么不测试正则表达式。
  例如:
  location = / { # 只匹配 / 查询。
  location / { # 匹配任何查询,因为所有请求都已 / 开头。但正则表达式规则和长的块规则将被优先和查询匹配。
  location ^~ /images/ { # 匹配任何已 /images/ 开头的任何查询并且停止搜索。任何正则表达式将不会被测试。
  location ~* \.(gif|jpg|jpeg)$ { # 匹配任何以 gif、jpg 或 jpeg 结尾的请求。
  ++ 文件及目录匹配
  * -f和!-f用来判断是否存在文件
  * -d和!-d用来判断是否存在目录
  * -e和!-e用来判断是否存在文件或目录
  * -x和!-x用来判断文件是否可执行
  ++ 一些可用的全局变量

  • $args

  • $content_length

  • $content_type

  • $document_root

  • $document_uri

  • $host

  • $http_user_agent

  • $http_cookie

  • $limit_rate

  • $request_body_file

  • $request_method

  • $remote_addr

  • $remote_port

  • $remote_user

  • $request_filename

  • $request_uri

  • $query_string

  • $scheme

  • $server_protocol

  • $server_addr

  • $server_name

  • $server_port

  • $uri
  Location必须放在server中
  这个指令随URL不同而接受不同的结构。你可以配置使用常规字符串和正则表达式。如果使用正则表达式,你必须使用 ~* 前缀选择不区分大小写的匹配或者 ~ 选择区分大小写的匹配。
  确定 哪个location 指令匹配一个特定指令,常规字符串第一个测试。常规字符串匹配请求的开始部分并且区分大小写,最明确的匹配将会被使用(查看下文明白 nginx 怎么确定它)。然后正则表达式按照配置文件里的顺序测试。找到第一个比配的正则表达式将停止搜索。如果没有找到匹配的正则表达式,使用常规字符串的结果。
  有两个方法修改这个行为。第一个方法是使用 “=”前缀,将只执行严格匹配。如果这个查询匹配,那么将停止搜索并立即处理这个请求。例子:如果经常发生”/”请求,那么使用 “location = /” 将加速处理这个请求。
  第二个是使用 ^~ 前缀。如果把这个前缀用于一个常规字符串那么告诉nginx 如果路径匹配那么不测试正则表达式。
  而且它重要在于 NGINX 做比较没有 URL 编码,所以如果你有一个 URL 链接’/images/%20/test’ , 那么使用 “images/ /test” 限定location。
  总结,指令按下列顺序被接受:
  1. = 前缀的指令严格匹配这个查询。如果找到,停止搜索。
  2. 剩下的常规字符串,长的在前。如果这个匹配使用 ^~ 前缀,搜索停止。
  3. 正则表达式,按配置文件里的顺序。
  4. 如果第三步产生匹配,则使用这个结果。否则使用第二步的匹配结果。
  例子:
  location = / {
  # 只匹配 / 查询。
  [ configuration A ]
  }
  location / {
  # 匹配任何查询,因为所有请求都已 / 开头。但是正则表达式规则和长的块规则将被优先和查询匹配。
  [ configuration B ]
  }
  location ^~ /images/ {
  # 匹配任何已 /images/ 开头的任何查询并且停止搜索。任何正则表达式将不会被测试。
  [ configuration C ]
  }
  location ~* \.(gif|jpg|jpeg)$ {
  # 匹配任何已 gif、jpg 或 jpeg 结尾的请求。然而所有 /images/ 目录的请求将使用 Configuration C。
  [ configuration D ]
  }
  例子请求:
  / -> configuration A
  /documents/document.html -> configuration B
  /images/1.gif -> configuration C
  /documents/1.jpg -> configuration D
  注意:按任意顺序定义这4个配置结果将仍然一样。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-635778-1-1.html 上篇帖子: centos 6.4 安装 nginx-CORE 下篇帖子: Nginx中文手册
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表