本文为博主原创,转载请注明出处:

  先查看 一段 nginx 相关的配置:

location /test/   {
  set $arg_remote_addr $request_id;
  proxy_pass https://self-in_slb_test_service_01;
set $resp_status "-";
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_set_header Host $host;
proxy_next_upstream error timeout;
  rewrite /copyrighttest(.*) $1 break;
expires off;
} upstream self-in_slb_test_service_01 {
server 112.118.0.154:8000 max_fails=0 fail_timeout=180 weight=1;
server 112.118.0.155:8000 max_fails=0 fail_timeout=180 weight=1;
    keepalive 64; 
}

  根据上述的配置,分别探究 prxoy_pass与 upstream  , rewrite的配置与功能

1.  prxoy_pass与 upstream 配置与功能:

  prxoy_pass 用来指定当前模块中请求的URL 或服务器的地址,当配置指定访问的URL 时,其配置如下:

 proxy_pass http://localhost:8000/uri/;

  当配置多个服务器地址时,需要配合 nginx 的 upstream 模块一起使用。upstream 为nginx 的负载均衡模块。

  Nginx 实现负载均衡需要基于 upstream 模块,同时需要设置 location proxy_pass 转发指令实现。

  最上面示例中的 upstream self-in_slb_test_service_01 中的 self-in_slb_test_service_01 为负载均衡的模块的名称,可以任意指定,但需要与vhosts.conf, nginx.conf 虚拟主机中的 proxy_pass 段保持一致,否则不能将请求转发到指定的后端服务器, weight 表示 权重,fail_timeout内检查 max_fails 次数,失败则剔除均衡。

2. expires 配置

  expires  定义用户浏览器缓存的时间,通过 Expires 参数设置,可以使浏览器缓存过期时间,减少与服务器之前的请求和流量。具体 Expires 定义是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量。如果静态页面不常更新,可以设置 指定的时间,这样可以节省带宽和缓解服务器的压力,在浏览器保存该类型文件的天数。expires  off 为关闭缓存。其设置可以参考如下:

expires 3d;  # 缓存3天

3. Nginx Rewrite 规则  

  Rewirte 规则也称为规则重写,主要功能是实现浏览器访问 HTTP URL 的跳转,其正则表达式是基于 Perl 语言。通常而言,几乎所有的 WEB 服务器均可以支持 URL 重写。

  URL 规则重写的用途:

    1.隐藏网站 URL 真实地址,浏览器显示更加美观;

    2.网站变更升级,可以基于 Rewrite 临时重定向到其他页面。

  Nginx Rewrite 规则使用中有三个概念需要理解,分别是:Rewrite 结尾标识符、Rewrite规则常用表达式、Nginx Rewrite 变量,如下为三个概念的详解:

    (1)Nginx Rewrite 结尾标识符,用于 Rewrite 规则末尾,表示规则的执行属性   

        last :      相当于 Apache 里的(L)标记,表示完成 rewrite 匹配;
        break:      本条规则匹配完成后,终止匹配,不再匹配后面的规则。
        redirect:     返回 302 临时重定向,浏览器地址会显示跳转后的 URL 地址。
        permanent:     返回 301 永久重定向,浏览器地址栏会显示跳转后的 URL 地址。
      其中 last 和 break 用来实现 URL 重写时,浏览器地址栏 URL 地址不变。

      (2)Nginx Rewrite 规则常用表达式,主要用于匹配参数、字符串及过滤设置。

        .         匹配任何单字符;      

        [word]          匹配字符串:word;

        [^word]      不匹配字符串:word;
        jfedu|jfteach   可选择的字符串:jfedu|jfteach;
        ?          匹配 0 到 1 个字符;
        *        匹配 0 到多个字符;
        +        匹配 1 到多个字符;
        ^        字符串开始标志;
        $        字符串结束标志;
        \n          转义符标志。

     (3)Nginx Rewrite 变量,常用于匹配 HTTP 请求头信息、浏览器主机名、URL 等。

HTTP_USER_AGENT              用户使用的代理,例如浏览器;
HTTP_REFERER                告知服务器,从哪个页面来访问的;
HTTP_COOKIE                 客户端缓存,主要用于存储用户名和密码等信息;
HTTP_HOST                  匹配服务器 ServerName 域名;
HTTP_ACCEPT                 客户端的浏览器支持的 MIME 类型;
REMOTE_ADDR                 客户端的 IP 地址
QUERY_STRING                URL 中访问的字符串;
DOCUMENT_ROOT                服务器发布目录;
SERVER_PORT                 服务器端口;
SERVER_PROTOCOL              服务器端协议;
TIME_YEAR                  年;
TIME_MON                  月;
TIME_DAY                  日;

      (4) 示例配置

        将 testa.net 跳转至 www.testb.net。    

      if ($host = 'testa.net' ) {
          rewrite ^/(.*)$ http://www.testb.net/$1  permanent;
      }

        访问/test/test01/跳转至/newindex.html,浏览器地址不变。 

      rewrite  ^/jfedu/test01/$  /newindex.html  last;

4. $1,$2 的意义

  表示路径中正则表达式匹配的第一个参数

  

nginx 负载均衡 proxy_pass 与 upstream 及 rewrite ,expires 的配置总结的更多相关文章

  1. [转载]nginx负载均衡+keepalived三主(多主)配置

    nginx负载均衡+keepalived三主(多主)配置 1.实验环境,实现目标三台主机分别配置nginx负载均衡对后端多台主机做转发,同时配置keepalived实现HA,保证任意主机出现故障时其他 ...

  2. Nginx 负载均衡演示之 upstream 参数 & location 参数

    upstream 参数nginx关于upstream参数官方文档:http://nginx.org/en/docs/http/ngx_http_upstream_module.html upstrea ...

  3. Nginx负载均衡配置与负载策略

    原理 负载均衡的目的是为了解决单个节点压力过大,造成Web服务响应过慢,严重的情况下导致服务瘫痪,无法正常提供服务. 应用场景 春节期间在12306网站上买过火车票的朋友应该深有体会,有时查询一张火车 ...

  4. Nginx系列篇二:linux搭建Nginx负载均衡

    建议先搭建好Nginx环境 可阅读--->Linux中搭建Nginx 1.准备好三台服务器[标配] 一.nginx负载均衡服务器:192.168.102.110,配置好Nginx 二.tomca ...

  5. Nginx负载均衡的max_fails和fail_timeout的默认配置问题

    今天发现一个奇怪的现象,前端请求后端服务多次后会超时一次,经过多次验证确定是大概10s左右就会超时一次,检查后端服务,发现其中一个节点已经夯死. 但是我们的nginx负载均衡策略是轮询机制,按照配置来 ...

  6. nginx负载均衡(5种方式)、rewrite重写规则及多server反代配置梳理

    Nginx除了可以用作web服务器外,他还可以用来做高性能的反向代理服务器,它能提供稳定高效的负载均衡解决方案.nginx可以用轮询.IP哈希.URL哈希等方式调度后端服务器,同时也能提供健康检查功能 ...

  7. (转)nginx负载均衡(5种方式)、rewrite重写规则及多server反代配置梳理

    Nginx除了可以用作web服务器外,他还可以用来做高性能的反向代理服务器,它能提供稳定高效的负载均衡解决方案.nginx可以用轮询.IP哈希.URL哈希等方式调度后端服务器,同时也能提供健康检查功能 ...

  8. nginx反向代理,负载均衡,动静分离,rewrite地址重写介绍

    一.rewrite地址重写 地址转发后客户端浏览器地址栏中的地址显示是不变的,而地址重写后地址栏中的地址会变成正确的地址. 在一次地址转发过程中只会产生一次网络请求,而一次地址重写产生两次请求. 地址 ...

  9. Nginx系列一:正向代理和反向代理、Nginx工作原理、Nginx常用命令和升级、搭建Nginx负载均衡

    转自https://www.cnblogs.com/leeSmall/p/9351343.html 仅供个人学习 一.什么是正向代理.什么是反向代理 1. 正向代理,意思是一个位于客户端和原始服务器( ...

  10. [转]Nginx负载均衡原理初解

    什么是负载均衡 我们知道单台服务器的性能是有上限的,当流量很大时,就需要使用多台服务器来共同提供服务,这就是所谓的集群. 负载均衡服务器,就是用来把经过它的流量,按照某种方法,分配到集群中的各台服务器 ...

随机推荐

  1. MD5在文件安全中的应用与重要性

    一.MD5简介 MD5(Message-Digest Algorithm 5)是一种广泛应用的密码散列函数,由美国密码学家罗纳德·李维斯特(Ronald Linn Rivest)于1992年提出.它主 ...

  2. 常用API之IP定位地区

    常用API之IP定位地区 高德地图API https://lbs.amap.com/api/webservice/guide/api/ipconfig 百度地图API https://lbsyun.b ...

  3. MySQL|空间碎片化问题处理

    一.空间碎片化严重案例分享 1.1 问题描述 实例磁盘空间近1个月上涨趋势明显,主要是个别日志表存储较大且部分表存在空间碎片化的现象. 1.2 处理流程 1.通过日常巡检以及监控发现某实例磁盘空间近1 ...

  4. linux文件和文件夹的筛选、查找及用户和组管理命令

    1.列出当前系统上所有已经登陆的用户的用户名, 注意:同一个用户登录多次,则只显示一次即可. 查看系统用户的命令为: (1)getent passwd 查看系统上的所有用户信息 (2)w 查看登录用户 ...

  5. STM32CubeMX教程13 ADC - 单通道转换

    1.准备材料 开发板(正点原子stm32f407探索者开发板V2.4) ST-LINK/V2驱动 STM32CubeMX软件(Version 6.10.0) keil µVision5 IDE(MDK ...

  6. AI 图像自动补全 Uncrop 工具介绍

    ClipDrop Uncrop是一款基于AI的图像自动补全工具,由StabilityAI旗下的Clipdrop开发.通过利用StableDiffusionXL开发的算法和深度学习技术,Uncrop可以 ...

  7. 全域Serverless+AI,华为云加速大模型应用开发

    日前,华为全联接大会2023在上海召开.华为云CTO张宇昕在大会上发布了基于Serverless技术的大模型应用开发框架,框架以面向AI领域全新升级的FunctionGraph 3.0为核心,将Baa ...

  8. 基于ModelArts进行流感患者密接排查

    摘要:针对疫情期间存在的排查实时性差.排查效率低.无法追踪密接者等问题,可以使用基于YOLOv4的行人检测.行人距离估计.多目标跟踪的方案进行解决. 本文分享自华为云社区<基于ModelArts ...

  9. 人人都在聊的云原生数据库Serverless到底是什么?

    摘要:华为云数据库营销专家Tony Chen和华为云数据库高级产品经理佳恩开展了一场关于云原生数据库与Serverless结合的直播对话. 云计算的迅猛发展推动了数据库的变革,云原生数据库成为当前数据 ...

  10. 消除视觉Transformer与卷积神经网络在小数据集上的差距

    摘要:本文通过多种操作构建混合模型,增强视觉Transformer捕捉空间相关性的能力和其进行通道多样性表征的能力,弥补了Transformer在小数据集上从头训练的精度与传统的卷积神经网络之间的差距 ...