• Nginx配置教程


    笔记来自
    配置教程一
    配置教程二

    配置文件

    - event块
    - http块
       - http全局块
       - upstream负载均衡配置
       - service块
          - location块
            - alias与root的区别
            - 多个server匹配优先级
            - location匹配规则
            - proxy_pass
    

    alias与root的区别

    • root 实际访问文件路径会拼接URL中的路径
    • alias 实际访问文件路径不会拼接URL中的路径
    location ^~ /sta/ {  
       alias /usr/local/nginx/html/static/;  
    }
    # 请求:http://test.com/sta/sta1.html
    # 实际访问:/usr/local/nginx/html/static/sta1.html 文件
    
    location ^~ /tea/ {  
       root /usr/local/nginx/html/;  
    }
    # 请求:http://test.com/tea/tea1.html
    # 实际访问:/usr/local/nginx/html/tea/tea1.html 文件
    

    多个server匹配优先级
    在开始处理一个http请求时,nginx会取出header头中的host,与nginx.conf中每个server的server_name进行匹配,以此决定到底由哪一个server块来处理这个请求。
    server_name与host匹配优先级如下:

    • 完全匹配
    • 通配符在前的,如*.test.com
    • 在后的,如www.test.*
    • 正则匹配,如~^.www.test.com$

    如果都不匹配

    • 优先选择listen配置项后有default或default_server的
    server {
        listen      80 default_server;
        server_name example.net www.example.net;
        ...
    }
    
    • 没有default就匹配listen端口的第一个server块

    location匹配规则

    • = 开头表示精确匹配,如 A 中只匹配根目录结尾的请求,后面不能带任何字符串
    • ^~ 开头表示 uri 以某个常规字符串开头,不是正则匹配
    • ~ 开头表示区分大小写的正则匹配
    • ~* 开头表示不区分大小写的正则匹配
    • / 通用匹配,如果没有其它匹配,任何请求都会匹配到
    • /images/ 匹配任何以 /images/ 开头的地址
    location  = / {
      # 精确匹配 /,主机名后面不能带任何字符串
      [ config A ]
    }
    
    location / {
      # 因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求
      # 但是正则和最长字符串会优先匹配,无其他匹配内容的时候才走到这里
      [ config B ]
    }
    
    location /documents/ {
      # 匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索
      # 只有后面的正则表达式没有匹配到时,这一条才会采用这一条
      [ config C ]
    }
    
    location ^~ /images/ {
      # 匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条
      [ config D ]
    }
    
    location ~* .(gif|jpg|jpeg)$ {
      # 匹配所有以 gif、jpg 或 jpeg 结尾的请求
      # 所有请求 /images/ 下的图片会被 config D 处理,因为 ^~ 到达不了这一条正则
      [ config E ]
    }
    
    location /images/ {
      # 字符匹配到 /images/,继续往下,会发现 ^~ 存在
      [ config F ]
    }
    
    location /images/abc {
      # 最长字符匹配到 /images/abc,继续往下,会发现 ^~ 存在
      # F 与 G 的放置顺序是没有关系的
      [ config G ]
    }
    
    location ~ /images/abc/ {
      # 只有去掉 config D 才有效:先最长匹配 config G 开头的地址,继续往下搜索,匹配到这一条正则,采用
      [ config H ]
    }
    
    location ~* /js/.*/.js
    

    location的proxy_pass 后面的url加与不加【/】的区别
    没有【/】时,location /abc/def可以匹配/abc/defghi请求,也可以匹配/abc/def/ghi等
    而有【/】时,location /abc/def/不能匹配/abc/defghi请求,只能匹配/abc/def/anything这样的请求

    # 下面四种情况分别用http://192.168.1.4/proxy/test.html 进行访问
    # 第一种:会被代理到http://127.0.0.1:81/test.html 这个url
    location  /proxy/ {
       proxy_pass http://127.0.0.1:81/;
    }
    
    # 第二种,会被代理到http://127.0.0.1:81/proxy/test.html 这个url
    location  /proxy/ {
       proxy_pass http://127.0.0.1:81;
    }
    
    # 第三种:会被代理到http://127.0.0.1:81/ftlynx/test.html 这个url
    location  /proxy/ {
       proxy_pass http://127.0.0.1:81/ftlynx/;
    }
    
    # 第四种(相对于第三种,最后少一个 / ):会被代理到http://127.0.0.1:81/ftlynxtest.html 这个url
    location  /proxy/ {
       proxy_pass http://127.0.0.1:81/ftlynx;
    }
    

    负载均衡的策略
    跟server是同一级配置

    • 轮询策略
    // 默认情况下采用的策略,将所有客户端请求轮询分配给服务端。
    // 这种策略是可以正常工作的,但是如果其中某一台服务器压力太大,出现延迟,会影响所有分配在这台服务器下的用户。
    upstream balanceServer {
        server 10.1.22.33:12345;
        server 10.1.22.34:12345;
        server 10.1.22.35:12345;
    }
    
    • 最小连接数策略
    // 将请求优先分配给压力较小的服务器,它可以平衡每个队列的长度,并避免向压力大的服务器添加更多的请求。
    upstream balanceServer {
        least_conn;
        server 10.1.22.33:12345;
        server 10.1.22.34:12345;
        server 10.1.22.35:12345;
    }
    
    • 最快响应时间策略
    // 依赖于NGINX Plus,优先分配给响应时间最短的服务器。
    upstream balanceServer {
        fair;
        server 10.1.22.33:12345;
        server 10.1.22.34:12345;
        server 10.1.22.35:12345;
    }
    
    • 客户端ip绑定
    // 来自同一个ip的请求永远只分配一台服务器,有效解决了动态网页存在的session共享问题。
    upstream balanceServer {
        ip_hash;
        server 10.1.22.33:12345;
        server 10.1.22.34:12345;
        server 10.1.22.35:12345;
    }
    

    nginx除了反向代理,还可以作为了一个优秀的网关的存在,具体查看【Nginx使用Lua】笔记

  • 相关阅读:
    mac下crontab定时任务使用
    javascript入门之算术乘法表
    原型模型
    Servlet开发
    工厂模式
    简单工厂模式
    Java设计模式之瞎BB的官话
    JavaBean技术
    软件设计模式之单例模式
    JSP页面请求与响应以及保存页面状态
  • 原文地址:https://www.cnblogs.com/pengdt/p/13062340.html
Copyright © 2020-2023  润新知