nginx动静分离配置实例

什么是动静分离

ngnix动静分离简单来说就是把动态请求和静态请求分开。不能理解成只是单纯的把动态页面和静态页面物理分离。
可以理解成使用nginx处理静态页面,使用tomcat处理动态页面。
动静分离目前从实现角度上可以分为两种:

  1. 纯粹把静态文件独立成单独的域名,放在独立的服务器上。也是目前推崇的方案。
    在这里插入图片描述
  2. 动态和静态文件混合在一起发布,通过nginx来分开。

实现是:通过location指定不同的后缀名实现不同的请求转发。通过expires参数设置,可以使浏览器缓存过期时间,减少与服务器之间的请求和流量。
具体expires定义:是给一个资源设定一个过期时间,也就是说无需去服务器验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量,此种方法不适合经常变动的资源(如果经常更新的文件,不建议使用expires来缓存)。
比如:expires设置3d,表示在这3天内访问这个URL,发送一个请求,比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码304,如果有修改,则直接从服务器重新下载,返回状态码200。

准备工作

  1. 在nginx中准备一些静态资源,用于进行访问。
    在根目录下创建data目录,在data目录下创建www和image目录。在www目录下创建html网页文件,在image目录下创建jpg图片文件。
    在这里插入图片描述

实现效果

静态资源没有保存在tomcat中,而是保存在了云服务器上,通过nginx直接访问。

在浏览器请求静态资源,直接通过nginx获取,不通过tomcat获取。
nginx负载均衡实例nginx反向代理实例都是通过tomcat来获取资源的实例,下面就不实现了。

具体配置

找到nginx配置位置:/usr/local/nginx/conf/nginx.conf
进行nginx配置的修改:
在这里插入图片描述
重新加载nginx或重启nginx:./nginx -s reload 或 ./nginx

演示

输入:114.55.92.82:8080/www/a.html(nginx服务器地址和运行端口加静态资源位置)。不需要输入根目录data,在配置中已经设置。
在这里插入图片描述
输入:114.55.92.82:80/image,测试配置的autoindex。
在这里插入图片描述
输入:114.55.92.82:80/image/a.jpg,获取图片资源。
在这里插入图片描述

相关推荐

  1. Nginx配置实现动静分离

    2024-07-19 02:38:02       49 阅读
  2. nginx 实现动静分离

    2024-07-19 02:38:02       55 阅读
  3. Nginx动静分离

    2024-07-19 02:38:02       39 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-19 02:38:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-19 02:38:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-19 02:38:02       58 阅读
  4. Python语言-面向对象

    2024-07-19 02:38:02       69 阅读

热门阅读

  1. 【Unity C#优化】业务逻辑代码方面的优化

    2024-07-19 02:38:02       21 阅读
  2. 【Linux】微基准测试

    2024-07-19 02:38:02       20 阅读
  3. AI发展下的伦理挑战,应当如何应对?

    2024-07-19 02:38:02       19 阅读
  4. 软件测试有光明的未来

    2024-07-19 02:38:02       20 阅读
  5. 1、PostgreSQL安装

    2024-07-19 02:38:02       20 阅读
  6. 数组reduce的众多用法

    2024-07-19 02:38:02       21 阅读
  7. 泛型+反射

    2024-07-19 02:38:02       18 阅读
  8. 牛客周赛51

    2024-07-19 02:38:02       22 阅读
  9. 开始构建我们自己的大语言模型:数据处理部分

    2024-07-19 02:38:02       21 阅读
  10. Vue.js(第一天)

    2024-07-19 02:38:02       21 阅读
  11. ThreadPoolExecutor拒绝策略

    2024-07-19 02:38:02       23 阅读