Nodejs下DNS緩存問題淺析
無意間看到一個文章,是關(guān)于nodejs下發(fā)送http請求不會緩存dns結(jié)果的。這意味著,如果你基于nodejs寫了一個http采集程序,不提供dns緩存則會讓每次請求都傻傻的重復(fù)解析域名為ip地址。聽起來會非常影響性能不是么?
我的項目中,發(fā)送http請求并不是使用的node原生的http庫,而是依賴一個常用的Request庫。我查閱了一下該庫的相關(guān)文檔和github issue,也發(fā)現(xiàn)了一些和dns相關(guān)的帖子。不過多數(shù)說的是,關(guān)于dns問題,本身并不是Request庫的范疇,而歸結(jié)于nodejs的內(nèi)核問題。omg,感覺好深奧啊!
幸好,上面提到的那篇文章中也提出了兩個解決方案:
應(yīng)用級別:dnscache
操作系統(tǒng)級別:Bind, dnsmasq 和 unbound
不論是哪個方案,看起來似乎都很簡單,只是安裝并初始化即可。但問題是,我們怎么來驗證它們真實有效?由于我本地的開發(fā)機操作系統(tǒng)環(huán)境是win7 64bit,所以上文提到的操作系統(tǒng)級別的方案我無法測試。那我們就來看一下應(yīng)用級別方案到底是否有效吧~~
首先,我們需要讓win能追蹤dns請求,這里我找到了一個軟件,下載后不需要安裝直接運行即可。然后,我們還需要一個清除緩存的方法,可以看這里,簡單說就是在終端中執(zhí)行:
ipconfig /flushdns
工具就準備完畢了,我們創(chuàng)建一個測試腳本:
const Request = require('request');
function fetch(url, callback){
Request.head({
url: url,
timeout: 10000,
tunnel: true,
gzip: true,
proxy: false,
followRedirect: false
}, callback);
}
let now = Date.now();
fetch('http://blog.kazaff.me', function(err, response, body){
console.log('lookup time without cache: ', Date.now() - now);
});
好的,現(xiàn)在打開DNSQuerySniffer,然后先清理一下本地DNS緩存,一切就緒后執(zhí)行我們的測試腳本node test.js。你會在DNSQuerySniffer中看到一次DNS請求及其相關(guān)信息。在一定的時間間隔內(nèi),反復(fù)運行我們的測試腳本你會發(fā)現(xiàn)并不會再次觸發(fā)DNS請求,這說明什么?我的win7環(huán)境本身就自帶操作系統(tǒng)級別的DNS緩存(只是緩存時間很短)。
修改我們的測試腳本如下:
const dnscache = require('dnscache')({
"enable": true
});
const Request = require('request');
function fetch(url, callback){
Request.head({
url: url,
timeout: 10000,
tunnel: true,
gzip: true,
proxy: false,
followRedirect: false
}, callback);
}
let now = Date.now();
fetch('http://priceline.com', function(err, response, body){
console.log('lookup time without cache: ', Date.now() - now);
setTimeout(function(){
now = Date.now();
fetch('http://priceline.com', function(err, response, body){
console.log('lookup time with cache: ', Date.now() - now);
});
}, 2000);
});
這次我們在執(zhí)行測試腳本后,快速清空本地DNS緩存(如果你手速不快,可以適當(dāng)延長setTimeout的觸發(fā)間隔),你會發(fā)現(xiàn),兩秒后的http請求并沒有重新查詢DNS,這說明什么?很明顯,我們的應(yīng)用自己維護了DNS緩存,所以第二次請求根本就不會關(guān)心操作系統(tǒng)本地是否存在對應(yīng)的DNS緩存記錄。
以上所述是小編給大家介紹的Nodejs下DNS緩存問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- node.js使用 http-proxy 創(chuàng)建代理服務(wù)器操作示例
- node.js使用http模塊創(chuàng)建服務(wù)器和客戶端完整示例
- javascript常用方法、屬性集合及NodeList 和 HTMLCollection 的瀏覽器差異
- Node.js中使用Log.io在瀏覽器中實時監(jiān)控日志(等同tail -f命令)
- nodejs讀取圖片返回給瀏覽器顯示
- node.js利用redis數(shù)據(jù)庫緩存數(shù)據(jù)的方法
- Nodejs基于LRU算法實現(xiàn)的緩存處理操作示例
- nodejs使用redis作為緩存介質(zhì)實現(xiàn)的封裝緩存類示例
- Node.js 實現(xiàn)簡單的無侵入式緩存框架的方法
- node Buffer緩存區(qū)常見操作示例
- node.js實現(xiàn)http服務(wù)器與瀏覽器之間的內(nèi)容緩存操作示例
相關(guān)文章
Node.js實現(xiàn)mysql連接池使用事務(wù)自動回收連接的方法示例
這篇文章主要介紹了Node.js實現(xiàn)mysql連接池使用事務(wù)自動回收連接的方法,結(jié)合實例形式分析了node.js操作mysql連接池實現(xiàn)基于事務(wù)的連接回收操作相關(guān)技巧,需要的朋友可以參考下2018-02-02
npm?ERR!?Node.js?v20.11.0錯誤的解決
在使用?npm?進行包管理和構(gòu)建項目的過程中,有時會遇到錯誤信息?npm?ERR!?Node.js?v20.11.0,本文就來介紹一下如何解決,感興趣的可以了解一下2024-02-02

