摘要:客戶端請求頭聲明瀏覽器支持的壓縮方式,服務(wù)端配置啟用壓縮,壓縮的文件類型,壓縮方式。建議設(shè)置成大于的字節(jié)數(shù),小于可能會越壓越大。
背景
如果你是個前端開發(fā)人員,你肯定知道線上環(huán)境要把js,css,圖片等壓縮,盡量減少文件的大小,提升響應(yīng)速度,特別是對移動端,這個非常重要。
壓縮 壓縮方式前端壓縮的方式很多,依賴java的有ant工具,前端自己打包壓縮的有g(shù)runt,gulp,webpack,這些壓縮也很重要,基本上能壓縮50%以上,下面我們對壓縮文件來個對比,如圖所示,這是未壓縮的
這是壓縮后的
高能預(yù)警?。?!gzip能在壓縮的基礎(chǔ)上再進(jìn)行壓縮50%以上?。?!
gzip壓縮原理但是不是每個瀏覽器都支持gzip的,如果知道客戶端是否支持gzip呢,請求頭中有個Accept-Encoding來標(biāo)識對壓縮的支持??蛻舳薶ttp請求頭聲明瀏覽器支持的壓縮方式,服務(wù)端配置啟用壓縮,壓縮的文件類型,壓縮方式。當(dāng)客戶端請求到服務(wù)端的時候,服務(wù)器解析請求頭,如果客戶端支持gzip壓縮,響應(yīng)時對請求的資源進(jìn)行壓縮并返回給客戶端,瀏覽器按照自己的方式解析,在http響應(yīng)頭,我們可以看到content-encoding:gzip,這是指服務(wù)端使用了gzip的壓縮方式。
那么怎么看有沒有用gzip壓縮的文件呢,打開f12,查看network,按照下面的方式過濾
content-encoding是gzip的話就說明返回的是gzip
如何啟用gzip前面說過了,啟用gzip需要客戶端和服務(wù)端的支持,如果客戶端支持gzip的解析,那么只要服務(wù)端能夠返回gzip的文件就可以啟用gzip了,現(xiàn)在來說一下幾種不同的環(huán)境下的服務(wù)端如何配置
node端node端很簡單,只要加上compress模塊即可,代碼如下
var compression = require("compression") var app = express(); //盡量在其他中間件前使用compression app.use(compression());
這是基本用法,如果還要對請求進(jìn)行過濾的話,還要加上
app.use(compression({filter: shouldCompress})) function shouldCompress (req, res) { if (req.headers["x-no-compression"]) { // 這里就過濾掉了請求頭包含"x-no-compression" return false } return compression.filter(req, res) }
更多用法請移步compression文檔
如果用的是koa,用法和上面的差不多
const compress = require("koa-compress"); const app = module.exports = new Koa(); app.use(compress());
因為node讀取的是生成目錄中的文件,所以要先用webpack等其他工具進(jìn)行壓縮成gzip,webpack的配置如下
const CompressionWebpackPlugin = require("compression-webpack-plugin"); plugins.push( new CompressionWebpackPlugin({ asset: "[path].gz[query]",// 目標(biāo)文件名 algorithm: "gzip",// 使用gzip壓縮 test: new RegExp( ".(js|css)$" // 壓縮 js 與 css ), threshold: 10240,// 資源文件大于10240B=10kB時會被壓縮 minRatio: 0.8 // 最小壓縮比達(dá)到0.8時才會被壓縮 }) );
plugins是webpack的插件
tomcattomcat的配置如下
找到tomcat的server.xml文件,找到其中Connector節(jié)點然后進(jìn)行配置修改,具體配置如下
參數(shù)說明:
compression="on" 打開壓縮功能
compressionMinSize="2048" 啟用壓縮的輸出內(nèi)容大小,當(dāng)被壓縮對象的大小>=該值時才會被壓縮,這里面默認(rèn)為2KB
noCompressionUserAgents="gozilla, traviata" 對于以下的瀏覽器,不啟用壓縮
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain" 壓縮類型
注意:tomcat7以后,js文件的mimetype類型變?yōu)榱薬pplication/javascript,而在tomcat7以下則為text/javascript;具體的tomcat7定義的類型可以在:conf/web.xml文件中找到。
可以在web.xml下搜索,如我搜索javascript會找到如下代碼
js application/javascript
切記上面的類型不能配置錯了,如果配置錯了壓縮是不會起作用的。
nginxgzip使用環(huán)境:http,server,location,if(x),一般把它定義在nginx.conf的http{…..}之間
gzip on
on為啟用,off為關(guān)閉
gzip_min_length 1k
設(shè)置允許壓縮的頁面最小字節(jié)數(shù),頁面字節(jié)數(shù)從header頭中的Content-Length中進(jìn)行獲取。默認(rèn)值是0,不管頁面多大都壓縮。建議設(shè)置成大于1k的字節(jié)數(shù),小于1k可能會越壓越大。
gzip_buffers 4 16k
獲取多少內(nèi)存用于緩存壓縮結(jié)果,‘4 16k’表示以16k*4為單位獲得
gzip_comp_level 5
gzip壓縮比(1~9),越小壓縮效果越差,但是越大處理越慢,所以一般取中間值;
gzip_types text/plain application/x-javascript text/css application/xml text/javascript application/x-httpd-php
對特定的MIME類型生效,其中"text/html’被系統(tǒng)強(qiáng)制啟用
gzip_http_version 1.1
識別http協(xié)議的版本,早起瀏覽器可能不支持gzip自解壓,用戶會看到亂碼
gzip_vary on
啟用應(yīng)答頭"Vary: Accept-Encoding"
gzip_proxied off
nginx做為反向代理時啟用,off(關(guān)閉所有代理結(jié)果的數(shù)據(jù)的壓縮),expired(啟用壓縮,如果header頭中包括"Expires"頭信息),no-cache(啟用壓縮,header頭中包含"Cache-Control:no-cache"),no-store(啟用壓縮,header頭中包含"Cache-Control:no-store"),private(啟用壓縮,header頭中包含"Cache-Control:private"),no_last_modefied(啟用壓縮,header頭中不包含"Last-Modified"),no_etag(啟用壓縮,如果header頭中不包含"Etag"頭信息),auth(啟用壓縮,如果header頭中包含"Authorization"頭信息)
gzip_disable msie6
(IE5.5和IE6 SP1使用msie6參數(shù)來禁止gzip壓縮 )指定哪些不需要gzip壓縮的瀏覽器(將和User-Agents進(jìn)行匹配),依賴于PCRE庫
以上代碼可以插入到 http {...}整個服務(wù)器的配置里,也可以插入到虛擬主機(jī)的 server {...}或者下面的location模塊內(nèi)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90409.html
摘要:協(xié)議上的編碼是一種用來改進(jìn)應(yīng)用程序性能的技術(shù)。目前主流的瀏覽器等都支持該協(xié)議。啟用或禁用響應(yīng)??山邮艿闹捣秶鸀榈健TO(shè)置將被壓縮的響應(yīng)的最小長度。長度僅由響應(yīng)頭字段確定。而里面的只是表示前端用戶瀏覽器支持的壓縮方式。 gzip是GNUzip的縮寫,它是一個GNU自由軟件的文件壓縮程序。它最早由Jean-loup Gailly和Mark Adler創(chuàng)建,用于UNⅨ系統(tǒng)的文件壓縮。我們在Li...
摘要:客戶端請求頭聲明瀏覽器支持的壓縮方式,服務(wù)端配置啟用壓縮,壓縮的文件類型,壓縮方式。建議設(shè)置成大于的字節(jié)數(shù),小于可能會越壓越大。 背景 如果你是個前端開發(fā)人員,你肯定知道線上環(huán)境要把js,css,圖片等壓縮,盡量減少文件的大小,提升響應(yīng)速度,特別是對移動端,這個非常重要。 壓縮 壓縮方式 前端壓縮的方式很多,依賴java的有ant工具,前端自己打包壓縮的有g(shù)runt,gulp,webp...
摘要:業(yè)務(wù)和架構(gòu)不分家,架構(gòu)是建立在對業(yè)務(wù)的理解之上的。主鍵最好保持順序遞增,隨機(jī)主鍵會導(dǎo)致聚簇索引樹頻繁分裂,隨機(jī)增多,數(shù)據(jù)離散,性能下降。沒有索引的更新,可能會導(dǎo)致全表數(shù)據(jù)都被鎖住。 本博客并非全部原創(chuàng),其實是一個知識的歸納和匯總,里面我引用了很多網(wǎng)上、書上的內(nèi)容。也給出了相關(guān)的鏈接。 本文涉及的知識點比較多,大家可以根據(jù)關(guān)鍵字去搜索相關(guān)的內(nèi)容和購買相應(yīng)的書籍進(jìn)行系統(tǒng)的學(xué)習(xí)。不對的地方...
摘要:所有的高階抽象組件是通過定義選項來聲明的。所以一般在生命周期或者中,需要用實例的方法清除可當(dāng)你有多個時,就需要重復(fù)性勞動銷毀這件事兒。更多的配置請看雙端開啟開啟壓縮的好處是什么可以減小文件體積,傳輸速度更快。本文目錄 接口模塊處理 Vue組件動態(tài)注冊 頁面性能調(diào)試:Hiper Vue高階組件封裝 性能優(yōu)化:eventBus封裝 webpack插件:真香 本文項目基于Vue-Cli3,想知...
摘要:自己是做前端開發(fā)的,在性能方面,根據(jù)的調(diào)查,后臺只占,而前端高達(dá)之多,其中有的東西是可以優(yōu)化的。相信很多人都聽過優(yōu)化網(wǎng)站性能的條規(guī)則。淘寶和阿里巴巴中文站目前都是這樣做的。目前的瀏覽器都能良好地支持。 相信互聯(lián)網(wǎng)已經(jīng)越來越成為人們生活中不可或缺的一部分。Ajax,flex等等富客戶端的應(yīng)用使得人們越加幸福地體驗著許多原先只能在C/S實現(xiàn)的功能。比如Google機(jī)會已經(jīng)把最基本的o...
閱讀 2058·2021-09-07 10:14
閱讀 1491·2019-08-30 15:53
閱讀 2278·2019-08-30 12:43
閱讀 2870·2019-08-29 16:37
閱讀 765·2019-08-26 13:29
閱讀 2009·2019-08-26 13:28
閱讀 450·2019-08-23 18:33
閱讀 3532·2019-08-23 16:09