nginx 配置实例(反向代理,负载均衡,动静分离)

反向代理配置

反向代理实例一
实现效果:使用 nginx 反向代理,本机访问 www .123 .com 直接跳转到 虚拟机127.169.72.129:8080

  1. 先启动虚拟机的tomcat

  2. 修改系统的host文件,将 www.123.com 映射到 虚拟机地址 192.168.72.129
    在这里插入图片描述

  3. 在 nginx.conf 配置文件中增加如下配置
    注意请编辑 安装目录下的nginx.conf 文件,本机地址在/usr/local/nginx/conf

    nginx 配置实例(反向代理,负载均衡,动静分离)_第1张图片
    在本地访问就会出现如下效果:
    nginx 配置实例(反向代理,负载均衡,动静分离)_第2张图片

反向代理实例二
实现效果:使用 nginx 反向代理,根据访问的路径跳转到不同端口的服务中
nginx 监听端口为 9001,
访问 http://127.168.72.129:9001/edu/ 直接跳转到 127.168.72.129:8080
访问 http://127.168.72.129:9001/vod/ 直接跳转到 127.168.72.130:8080

nginx.conf配置如下:

在nginx.conf 的 htpp 里面新加一个 server
nginx 配置实例(反向代理,负载均衡,动静分离)_第3张图片

location指令说明:
nginx 配置实例(反向代理,负载均衡,动静分离)_第4张图片

负载均衡

在2台服务器 129 和 130 分别启动tomcat

配置nginx.conf,在http 下新镇一个 server 和 upstream
nginx 配置实例(反向代理,负载均衡,动静分离)_第5张图片

Nginx 提供了几种访问分配方式(策略)

  1. 轮询(默认)

    每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。

  2. weight

    weight 代表权,重默认为 1,权重越高被分配的客户端越多
    指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。 例如:
    nginx 配置实例(反向代理,负载均衡,动静分离)_第6张图片

  3. ip_hash (每个客户端固定访问一个服务器)

    每个请求按访问 ip 的 hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 的问题。 例如:
    nginx 配置实例(反向代理,负载均衡,动静分离)_第7张图片

  4. fair
    nginx 配置实例(反向代理,负载均衡,动静分离)_第8张图片

动静分离

  1. Nginx 动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离。严格意义上说应该是动态请求跟静态请求分开,可以理解成使用 Nginx处理静态页面,Tomcat 处理动态页面。动静分离从目前实现角度来讲大致分为两种,
  2. 一种是纯粹把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案;
  3. 另外一种方法就是动态跟静态文件混合在一起发布,通过 nginx 来分开。
    通过 location 指定不同的后缀名实现不同的请求转发。通过 expires 参数设置,可以使浏览器缓存过期时间,减少与服务器之前的请求和流量。具体 Expires 定义:是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量。此种方法非常适合不经常变动的资源。(如果经常更新的文件,不建议使用 Expires 来缓存),我这里设置 3d,表示在这 3 天之内访问这个 URL,发送一个请求,比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码304,如果有修改,则直接从服务器重新下载,返回状态码 200

nginx配置:
找到 nginx 安装目录,打开/conf/nginx.conf 配置文件,
当我们放
nginx 配置实例(反向代理,负载均衡,动静分离)_第9张图片

你可能感兴趣的:(Nginx)