使用 NodeJS 操作網(wǎng)絡(luò)靈機(jī)一點(diǎn)

2018-09-28 20:41 更新

靈機(jī)一點(diǎn)

使用 NodeJS 操作網(wǎng)絡(luò),特別是操作 HTTP 請(qǐng)求和響應(yīng)時(shí)會(huì)遇到一些驚喜,這里對(duì)一些常見問題做解答。

問: 為什么通過 headers 對(duì)象訪問到的 HTTP 請(qǐng)求頭或響應(yīng)頭字段不是駝峰的?

答: 從規(guī)范上講,HTTP 請(qǐng)求頭和響應(yīng)頭字段都應(yīng)該是駝峰的。但現(xiàn)實(shí)是殘酷的,不是每個(gè) HTTP 服務(wù)端或客戶端程序都嚴(yán)格遵循規(guī)范,所以 NodeJS 在處理從別的客戶端或服務(wù)端收到的頭字段時(shí),都統(tǒng)一地轉(zhuǎn)換為了小寫字母格式,以便開發(fā)者能使用統(tǒng)一的方式來訪問頭字段,例如 headers['content-length']。

問: 為什么 http 模塊創(chuàng)建的 HTTP 服務(wù)器返回的響應(yīng)是 chunked 傳輸方式的?

答: 因?yàn)槟J(rèn)情況下,使用.writeHead方法寫入響應(yīng)頭后,允許使用.write方法寫入任意長度的響應(yīng)體數(shù)據(jù),并使用.end方法結(jié)束一個(gè)響應(yīng)。由于響應(yīng)體數(shù)據(jù)長度不確定,因此 NodeJS 自動(dòng)在響應(yīng)頭里添加了 Transfer-Encoding: chunked 字段,并采用 chunked 傳輸方式。但是當(dāng)響應(yīng)體數(shù)據(jù)長度確定時(shí),可使用.writeHead方法在響應(yīng)頭里加上 Content-Length 字段,這樣做之后 NodeJS 就不會(huì)自動(dòng)添加 Transfer-Encoding 字段和使用 chunked 傳輸方式。

問: 為什么使用 http 模塊發(fā)起 HTTP 客戶端請(qǐng)求時(shí),有時(shí)候會(huì)發(fā)生 socket hang up 錯(cuò)誤?

答: 發(fā)起客戶端 HTTP 請(qǐng)求前需要先創(chuàng)建一個(gè)客戶端。http 模塊提供了一個(gè)全局客戶端 http.globalAgent,可以讓我們使用.request.get方法時(shí)不用手動(dòng)創(chuàng)建客戶端。但是全局客戶端默認(rèn)只允許 5 個(gè)并發(fā) Socket 連接,當(dāng)某一個(gè)時(shí)刻 HTTP 客戶端請(qǐng)求創(chuàng)建過多,超過這個(gè)數(shù)字時(shí),就會(huì)發(fā)生 socket hang up 錯(cuò)誤。解決方法也很簡單,通過 http.globalAgent.maxSockets 屬性把這個(gè)數(shù)字改大些即可。另外,https 模塊遇到這個(gè)問題時(shí)也一樣通過 https.globalAgent.maxSockets 屬性來處理。

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)