Nginx静态压缩和代码压缩,提高访问速度!

程序员的成长之路

共 3459字,需浏览 7分钟

 · 2023-01-16

a0186910228883709ae03d671c6ac0a7.webp程序员的成长之路互联网/程序员/技术/资料共享  关注


阅读本文大概需要 2.8 分钟。

来自:juejin.cn/post/7101663374957608974

基于目前大部分的应用,都使用了前后端分离的框架,vue的前端应用,也是十分的流行。不知道大家有无遇到这样的问题:
随着前端框架的页面,功能开发不断的迭代;安装的依赖,不断的增多;这样导致的问题,就是我们的前端框架,会变得十分庞大,打包出来的dist目录会变得很大了喔!!!
这样就会导致一个问题:首次访问应用,会变得很慢!!!这确实是一个严重的问题!!!T_T对于这个问题,咋们今天就从代码压缩+nginx静态资源压缩,两个方面进行研究解决!!!

nginx静态资源动态压缩

  • nginx开启gzip压缩
    

server {
        listen       80;
        listen  [::]:80;
        server_name  localhost;
        server_tokens off;

        # 开启gzip压缩
        gzip on;
        gzip_disable "msie6";
        gzip_vary on;
        gzip_proxied any;
        gzip_comp_level 6;
        gzip_buffers 16 8k;
        gzip_http_version 1.1;
        gzip_types text/plain application/css text/css application/xml text/javascript application/javascript application/x-javascript;
        
        #llsydn 前端
        location /jxbp {           
             alias  /opt/llsydn/jxbp;
             index index.html;
             try_files $uri $uri/ /dist/index.html;
        }
 }      

然后重启nginx:nginx -s reload看看是否已经生效!!!
  • 压缩的效果图
77742e4f26fbda90673a81fad0fe3243.webp
  • 没有压缩的效果图
762eb6ad93feeba31a5473400ac6a2ad.webp从上面两张图可以看到:
  • 第一张经过压缩:finish时间为2.36s,transferred为7.6MB
  • 第二张没有压缩:finish时间为6.32s,transferred为24.6MB
很明显,经过了nginx的静态资源压缩,访问速度提高了,显著的!!!09252aa6bface908e832abbd4dd96a86.webp看到这,咋们会有这样的一个问题,这压缩都是nginx干的活,那当访问量变大,那对于nginx的压力,是十分大的,毕竟都是动态压缩的!!!那有无解决方法呢?nginx静态资源动态压缩的原理,无非就帮我们将js、css等文件,压缩为一个.gz文件,然后传输给前端浏览器,进行解析。说到这,咋们不禁会说:那咋们先将js、css等文件,生成对应的.gz文件,不就不需要nginx动态压缩了嘛?好像是这么一回事!!!天才呀!!!

nginx静态资源静态压缩

  • 将js、css等文件,生成对应的.gz文件
这个,就可以借助一些依赖进行处理了:compression-webpack-plugin安装依赖:
    

npm install compression-webpack-plugin -D

  • vue.config.js
    

const CompressionWebpackPlugin = require('compression-webpack-plugin')
const productionGzipExtensions = ['js''css']
vueConfig.configureWebpack.plugins.push(new CompressionWebpackPlugin({
    test:/.js$|.html$|.\css/, // 匹配文件名
    threshold: 1024, // 对超过1k的数据压缩
    deleteOriginalAssets: false // 不删除源文件
}))

打包:
    


npm run build

50102c3b50ecc3e9c5e4a7122bda848e.webp可以看到,已经帮我们生成对应的.gz文件了!!!
  • nginx配置
在上面的基础上,再加上
    

gzip_static on

  • nginx得安装下面得模块:
    

ngx_http_gzip_module模块
ngx_http_gzip_static_module模块
ngx_http_gunzip_module模块

  • nginx开启gzip压缩
    

server {
        listen       80;
        listen  [::]:80;
        server_name  localhost;
        server_tokens off;

        # 开启gzip压缩
        gzip on;
        gzip_static on
        gzip_disable "msie6";
        gzip_vary on;
        gzip_proxied any;
        gzip_comp_level 6;
        gzip_buffers 16 8k;
        gzip_http_version 1.1;
        gzip_types text/plain application/css text/css application/xml text/javascript application/javascript application/x-javascript;
        
        #llsydn 前端
        location /jxbp {           
             alias  /opt/llsydn/jxbp;
             index index.html;
             try_files $uri $uri/ /dist/index.html;
        }
 }      

然后重启nginx:nginx -s reload看看是否已经生效!!!
  • 静态压缩
f8aae7d3d2439f9f413b0346fdc0fafa.webp
  • 动态压缩
87d9b9afd6bbef107d8ea78a463b9505.webp好了,nginx的静态压缩,就到这里了!!!<END>

推荐阅读:

干掉 powerdesigner,设计数据库表用它就够了!

Spring Boot三步就能完成日志脱敏,简直太哇塞了!

    
        互联网初中高级大厂面试题(9个G)
      
    

内容包含Java基础、JavaWeb、MySQL性能优化、JVM、锁、百万并发、消息队列、高性能缓存、反射、Spring全家桶原理、微服务、Zookeeper......等技术栈!

戳阅读原文领取!                                   朕已阅  f4486f83206017cf15494bc65371662c.webp

浏览 24
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报