资讯专栏INFORMATION COLUMN

配置nginx静态文件代理和gzip

starsfun / 1609人阅读

摘要:接着上一篇在同一台服务器上配置和多个应用,这里记录下在下给配置静态代理和文件压缩。目的为了减少对静态文件的处理和加快前端下载静态资源的速度,决定使用做静态代理,并且对其进行压缩。最后对比发现这里的值在配置文件中没有包含为,而中配置的为

接着上一篇在同一台服务器上配置app1.domain.com和app2.domain.com多个web应用,这里记录下在nginx下给express web app配置静态代理和文件压缩。

目的

为了减少node.js对静态文件的处理和加快前端下载静态资源的速度,决定使用nginx做静态代理,并且对其进行gzip压缩。(为什么不使用express的compression中间,请移步:生产环境最佳实践:性能和可靠性)

静态文件代理 express项目结构

以上一篇中的blog应用为例,blog的express项目结构如下,所有的静态资源,例如js, css, font, image等都放在static目录下

- blog
    - dist
        - static
            - images
            - javascripts
            - stylesheets
            - fonts
            - font-awesome
            - ...
    - src
    - ...        

页面上所有引用资源时都是static/XXX/XXX/XXX.XXX

修改blog应用的nginx配置文件

blog的配置文件路径/etc/nginx/jackyang.me/blog.conf

upstream blog.jackyang.me {
    server 127.0.0.1:3000;
    keepalive 8;
}
 
server {
    listen 0.0.0.0:80;
    server_name blog.jackyang.me;

    location / {
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header Host $http_host;
      proxy_set_header X-NginX-Proxy true;
      proxy_pass http://blog.jackyang.me/;
      proxy_redirect off;
    }
    
    # new config lines for static files proxy
    location /static/ {
        root /var/www/jackyang.me/blog;
    }
 }

/static/的配置告诉nginx:碰到static/开头的任何请求,如:blog.jackyang.me/static/images/demo.png,都会去/var/www/jackyang.me/blog/static/目录下去找。

重启nginx
sudo /usr/local/nginx/sbin/nginx -s stop
sudo /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

重启nginx,查看expresslog,你将不会看到关于那些静态文件的GET请求。

开启gzip 修改blog应用的nginx配置文件

gzip可以配置在http, server, location作用域下,我这里是只为blog.jackyang.me配置,所以将其放在/etc/nginx/jackyang.me/blog.conf中:

upstream blog.jackyang.me {
    server 127.0.0.1:3000;
    keepalive 8;
}
 
server {
    listen 0.0.0.0:80;
    server_name blog.jackyang.me;

    location / {
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header Host $http_host;
      proxy_set_header X-NginX-Proxy true;
      proxy_pass http://blog.jackyang.me/;
      proxy_redirect off;
    }
    
    # new config lines for gzip
    gzip on;
    gzip_min_length 1k;
    gzip_buffers 4 8k;
    gzip_http_version 1.1;
    gzip_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml;
    
    location /static/ {
        root /var/www/jackyang.me/blog;
    }
 }

这里给了一个简单的配置,关于更多gzip的配置属性信息请查看官方文档

重启nginx
sudo /usr/local/nginx/sbin/nginx -s stop
sudo /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

打开浏览器访问页面,在调试工具中可以看到对应MINE类型的资源的response header中被标记gzip

(自己在配置时碰到问题,cssgzipjavascript没有。最后对比发现这里的Content-Type值在配置文件gzip_types中没有包含:content-typeapplication/javascript,而gzip_types中配置的为application/x-javascript

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/39243.html

相关文章

  • Nginx入门到实战(2)场景实现篇

    摘要:上一章了解了的基础理论与配置,这一章将介绍在各种不同场景下的不同使用方法一静态资源服务静态资源类型非服务器动态运行生成的文件,换句话说,就是可以直接在服务器上找到对应文件的请求浏览器端渲染图片视频文件,任意下载文件静态资源服务场景什么是例 上一章了解了nginx的基础理论与配置,这一章将介绍nginx在各种不同场景下的不同使用方法 一、静态资源WEB服务 1.静态资源类型 非服务器动态...

    netmou 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<