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

  先查看 一段 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. Docker命令之export|import、save|load

    1.export|import export docker export -o /ly/myexport-redis 49c26f7431d1 -o : 指定一个不存在的文件夹,存放导出的镜像 imp ...

  2. 安卓之各组件的LayoutParams分析

    文章摘要 在Android开发中,LayoutParams是一个非常重要的概念,它用于描述View在其父容器中的布局行为.不同的ViewGroup有不同的LayoutParams子类,例如Linear ...

  3. C++ Qt开发:Charts折线图绘制详解

    Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍QCharts ...

  4. Docker部署系列之Docker Compose安装Redis三主三从集群

    总结/朱季谦 在日常开发或者编程当中,经常需要用到redis集群,若是按照传统的方式,一个机器一个机器搭建,难免过于繁琐,故而可以通过dock er-compose编排方式,快速搭建.我在搭建过程当中 ...

  5. vivo 数据库备份恢复系统演化

    作者:vivo 互联网数据库团队 - Han Chaobing 介绍 vivo 数据库备份恢复功能的演化,以及对备份文件的功能扩展. 一.概述 vivo互联网领域拥有的数据库组件分别为 MySQL.M ...

  6. 春秋云镜 - CVE-2022-32991

    靶标介绍: 该CMS的welcome.php中存在SQL注入攻击. 访问页面,先注册,使用邮箱加密码登录. bp抓包,后台挂上sqlipy然后去测welcome.php,常用的语句都没成功但过一会就有 ...

  7. Rust 学习笔记

    rust 学习梳理 数据类型 基于已明确的类型,Rust会推断剩下大部分类型.基于类型推断Rust具备了与动态类型语言近似的易读性,并仍能在编译期捕获类型错误. 函数可以是泛型的:单个函数ujiu可以 ...

  8. 解决 git中用vim编写文件时,无法写进文字字母以及光标无法移到最右边的问题

    解决方法:可以切换到英文输入法,然后按'a' 或者 'i'  或者 'o' 或者's'  等.s好像会删掉一个字母.o会使光标移到文末.

  9. 文心一言 VS 讯飞星火 VS chatgpt (46)-- 算法导论6.1 4题

    四.假设一个最大堆的所有元素都不相同,那么该堆的最小元素应该位于哪里? 文心一言: 最大堆的最小元素位于堆的根结点.由于最大堆的性质,根结点是堆中所有元素的最大值,因此它也是堆中所有元素的最小值. 讯 ...

  10. 12、FlutterMediaQuery获取屏幕宽度和高度

    final size =MediaQuery.of(context).size; class HomePage3 extends StatelessWidget { const HomePage3({ ...