侧边栏壁纸
博主头像
张种恩的技术小栈博主等级

行动起来,活在当下

  • 累计撰写 748 篇文章
  • 累计创建 65 个标签
  • 累计收到 39 条评论

目 录CONTENT

文章目录

Nginx(5)之动静分离实例

zze
zze
2019-11-03 / 0 评论 / 0 点赞 / 600 阅读 / 1637 字

不定期更新相关视频,抖音点击左上角加号后扫一扫右方侧边栏二维码关注我~正在更新《Shell其实很简单》系列

什么是动静分离

Nginx 动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离。严格意义上说应该是动态请求跟静态请求分开,可以理解成使用 Nginx 处理静态页面,Tomcat 处理动态页面。
动静分离从目前实现角度来讲大致分为两种:

  • 一种是纯粹把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案;
  • 另外一种方法就是动态跟静态文件混合在一起发布,通过 Nginx 来分开。

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

  • 如果最后更新时间没有变化,则返回状态码 304,不会从服务器抓取;
  • 如果有修改,则返回状态码 200,直接从服务器重新下载;

实例

目标

通过 Nginx 来访问服务器上的静态资源。

步骤

1、在根目录下创建文件夹 www 用于存放静态资源,在 www 文件夹下新建 htmlimage 文件夹分别用于存放网页文件和图片,在这两个目录下分别放入 1.html1.jpg 用于测试。
2、修改 Nginx 配置文件的 server 节配置如下:

server {
    listen       80;
    server_name  www.123.com;

    location /html/ {
        alias  /www/html/;
        index  index.html index.htm;
    }

    location /image/ {
        alias /www/image/;
        autoindex on;
    }
}

3、测试访问 www.123.com/html/1.htmlwww.123.com/image/1.jpg

访问静态资源时 location 节下最好使用 alias 来指定映射目录,因为使用 root 会拼接请求 URI 前缀拼接到映射的目录路径后面。。。。之前使用 root 折腾了个把小时,修改为 alias 即可。试着捣腾吧,我也的确见人使用 root 也能访问成功的。。

0

评论区