node.js 開發的網站,如果你也是用了nginx實作反向代理.
那麼在服務端可以輕鬆實作gzip 壓縮,讓網站瀏覽更順暢.
前提條件: node.js nginx 反向代理.
node.js 需要做的工作:
express 4.0以下版本:
app.use(express.compress()); //主要是这句 app.use(express.json()); app.use(express.urlencoded()); app.use(express.bodyparser()); app.use(express.methodoverride()); app.use(express.cookieparser());
為了讓所有請求壓縮,所以compress放在上面.
express 4.0以上版本(包含4.0)
var compress = require('compression'); app.use(compress());
4.0以上版本把中間件獨立拿出來了.
所以首先需要你rquire('compression ')
點擊這裡查看express 3.5 和express 4.0 的主要區別
node.js 需要做的工作就是這麼簡單.
nginx 需要做的工作:
開啟nginx設定檔,修改設定,開啟gzip 開關
nano /usr/local/nginx/conf/nginx.conf
你自己伺服器上的nginx 不一定安裝在/usr/local/ 目錄下,所以根據自己安裝目錄下尋找設定檔nginx .conf
在http 設定節點上加上以下設定:
gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.0; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on; http ( //放上面配置节点 )
每一個設定項表示什麼意義呢?
1) gzip
##語法: gzip on/off預設值:off作用域:http, server, location說明:開啟或關閉gzip 模組,這裡使用on 表示啟動2) gzip_min_length語法:gzip_min_length length預設值:gzip_min_length 0#作用域:http, server, location說明:設定設定允許壓縮的頁面最小位元組數,頁面位元組數從header頭中的content-length中取得。預設值是0,不管頁面多大都壓縮。建議設定成大於1k的位元組數,小於1k可能會越壓越大。 |3) gzip_buffers語法: gzip_buffers number size預設值: gzip_buffers 4 4k/8k作用域: http, server, location說明:設定係統取得幾個單位的快取用於儲存gzip的壓縮結果資料流。 4 16k 代表以 16k 為單位,以原始資料大小以 16k 為單位的4倍申請記憶體。 4) gzip_comp_level語法: gzip_comp_level 1..9預設值: gzip_comp_level 1作用域: http, server, location#說明:gzip壓縮比,1 壓縮比最小處理速度最快,9 壓縮比最大但處理最慢(傳輸快但比較消耗cpu)。這裡設定為 5。 5) gzip_types語法: gzip_types mime-type [mime-type ...]預設值: gzip_types text/html作用域: http, server, location說明:符合mime類型進行壓縮,(無論是否指定)"text/html" 類型總是會被壓縮的。這裡設定為 application/x-javascript text/css application/xml。 常用的靜態 type 有,看自己需要壓縮的情況而定:
text/html text/plain text/css application/x-javascript text/javascript application/xmlok,到這裡基本服務端已經配置完畢,nginx 只需要 reload 一下即可。 下面來測試一下,用curl 來如何測試服務端已經開啟gzip(測試條件是預設gzip_types,即只壓縮text.html ,其他type 未壓縮):#查看是否開啟gzip,需要客戶端加入:"accept-encoding: gzip, deflate" 頭資訊。
$ curl -i -h "accept-encoding: gzip, deflate" "http://localhost/tag.php"
http/1.1 200 ok server: nginx date: thu, 08 mar 2012 07:23:46 gmt content-type: text/html connection: close content-encoding: gzip
$ curl -i -h "accept-encoding: gzip, deflate" "http://localhost/style.css"
http/1.1 200 ok server: nginx date: thu, 08 mar 2012 07:23:54 gmt content-type: text/css connection: close last-modified: tue, 27 dec 2011 10:00:51 gmt etag: "bc612352322d435769c4bdc03ddb2572" content-length: 22834可以看出來了把。第二個範例沒有被壓縮。
以上是Node.js網站使用Nginx作反向代理程式時怎麼配置GZip壓縮的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Vercel是什么?本篇文章带大家了解一下Vercel,并介绍一下在Vercel中部署 Node 服务的方法,希望对大家有所帮助!

gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。

本篇文章带大家详解package.json和package-lock.json文件,希望对大家有所帮助!

本篇文章给大家分享一个Nodejs web框架:Fastify,简单介绍一下Fastify支持的特性、Fastify支持的插件以及Fastify的使用方法,希望对大家有所帮助!

如何用pkg打包nodejs可执行文件?下面本篇文章给大家介绍一下使用pkg将Node.js项目打包为可执行文件的方法,希望对大家有所帮助!

node怎么爬取数据?下面本篇文章给大家分享一个node爬虫实例,聊聊利用node抓取小说章节的方法,希望对大家有所帮助!

本篇文章给大家分享一个Node实战,介绍一下使用Node.js和adb怎么开发一个手机备份小工具,希望对大家有所帮助!

先介绍node.js的安装,再介绍使用node.js构建一个简单的web服务器,最后通过一个简单的示例,演示网页与服务器之间的数据交互的实现。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。