gzip是GNUzip的缩写,它是一个GNU自由软件的文件压缩程序。它最先由Jean-loup Gailly和Mark Adler建立,用于UNⅨ系统的文件压缩。咱们在Linux中常常会用到后缀为.gz的文件,它们就是GZIP格式的。现今已经成为Internet 上使用很是广泛的一种数据压缩格式,或者说一种文件格式。javascript
HTTP协议上的GZIP编码是一种用来改进WEB应用程序性能的技术。大流量的WEB站点经常使用GZIP压缩技术来让用户感觉更快的速度。减小文件大小有两个明显的好处,一是能够减小存储空间,二是经过网络传输文件时,能够减小传输的时间。php
固然WEB服务器和客户端(浏览器)必须共同支持gzip。目前主流的浏览器Chrome,firefox,IE等都支持该协议。常见的服务器如Apache,Nginx,IIS一样支持gzip。css
下面就以Vue项目为例,介绍一下gzip的使用(vue-cli 2.*)html
1、在/config/index.js
中,修改配置开启gzip前端
// Gzip off by default as many popular static hosts such as // Surge or Netlify already gzip all static assets for you. // Before setting to `true`, make sure to: // npm install --save-dev compression-webpack-plugin productionGzip: true, productionGzipExtensions: ['js', 'css'],
在修改productionGzip
的默认值(false)为true以前,先安装所需的依赖npm install --save-dev compression-webpack-plugin
。vue
若是按上述操做完成后,打包时出错,建议更换低版本的compression-webpack-plugin
,推荐使用1.1.12或者1.1.11版本等
npm uninstall --save-dev compression-webpack-plugin
npm install --save-dev compression-webpack-plugin@1.1.12
java
2、在nginx中开启gzip,/nginx/conf/nginx.conf
中添加gzip配置webpack
http:{ #启用或禁用gzipping响应。# gzip on; #设置用于压缩响应的缓冲区number和size。默认状况下,缓冲区大小等于一个内存页面。这是4K或8K,具体取决于平台。# gzip_static on; #启用或禁用gzipping响应。# gzip_buffers 4 16k; #设置level响应的gzip压缩。可接受的值范围为1到9。# gzip_comp_level 5; #设置将被gzip压缩的响应的最小长度。长度仅由“Content-Length”响应头字段肯定。# gzip_min_length 100; #匹配MIME类型进行压缩,text/html默认被压缩。# gzip_types text/plain application/javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png; }
修改完nginx配置,重启服务。nginx
关于gzip详细的配置和描述,请查阅 Module ngx_http_gzip_moduleweb
至此,gzip已开启。你能够运行你的项目去检测一下。
打开Chrome控制台,能够看到Network
下的Response Headers
中返回了Content-Encoding: gzip
,代表gzip开启成功。
而Request Headers
里面的Accept-Encoding: gzip
只是表示前端(用户浏览器)支持gzip的压缩方式。
服务器支持gzip的方式能够有两种: 一、打包的时候生成对应的.gz文件,浏览器请求xx.js时,服务器返回对应的xxx.js.gz文件 二、浏览器请求xx.js时,服务器对xx.js进行gzip压缩后传输给浏览器