javascript - Nodejs服務(wù)器中 應(yīng)該何時(shí)res.end()呢?
問題描述
有這樣的一個(gè)場景 ’/blog’ 路由下要處理用戶提交的數(shù)據(jù)假設(shè)要把三份數(shù)據(jù)存儲(chǔ)給三個(gè)key 然后代碼寫出來就變成這樣
function handlePostBlog(req, res){ resid_client.set( key1, data1, function(err, response){resid_client.set(key2, data2, function(err,response){ resid_client.set(key3, data3, function(err, response){if(response === ’ok’){ res.writeHead(200, ...) res.end()} })}) })}
不考慮好不好看。。雖然用promise包裝的好看一些 但是在最后一個(gè)回調(diào)中res.end()來關(guān)閉連接,是不是存在問題?這個(gè)請(qǐng)求會(huì)被掛起很長一段時(shí)間把?一般這種地方應(yīng)該怎么處理?因?yàn)橹恍枰猻et而不需要返回結(jié)果給用戶,所以收到請(qǐng)求之后就直接res.end()來關(guān)閉連接可以不?
問題解答
回答1:這取決于你是否希望這個(gè) HTTP 請(qǐng)求的返回結(jié)果與數(shù)據(jù)庫操作的結(jié)果有關(guān)聯(lián)性,以及用戶交互設(shè)計(jì)是否容忍這個(gè)操作所花費(fèi)的時(shí)間。
你在設(shè)計(jì)這個(gè) ’/blog’ 接口時(shí),需要明確指明 HTTP 返回 200 意味著什么。如果你們的業(yè)務(wù)場景只關(guān)心數(shù)據(jù)交付到后端,不關(guān)心后端是否正確存儲(chǔ)到數(shù)據(jù)庫,那肯定可以直接結(jié)束掉 HTTP 請(qǐng)求。如果你們希望終端用戶得到這個(gè)確切的提交結(jié)果,那需要考慮交互層面了,設(shè)計(jì)良好的交互效果,2-6秒的等待,用戶體驗(yàn)不會(huì)很差(指AJAX請(qǐng)求場景下,打開新頁面場景下還是慎重)。寫三次redis幾乎是不花時(shí)間,比起 HTTP 請(qǐng)求本身的鏈路延遲根本不算什么。
具體業(yè)務(wù)場景還要具體分析。碰到特別耗時(shí)的操作,前端提交操作請(qǐng)求后輪訓(xùn)結(jié)果也不失為一種解決方案。
回答2:看頁面顯示和數(shù)據(jù)庫操作結(jié)果有沒有相關(guān)性。如果有相關(guān)性,可以等待數(shù)據(jù)庫操作結(jié)束之后返回。也可以做成異步隊(duì)列的方式直接返回,成功后在推送結(jié)果。最終怎么樣,還是看你需求。
相關(guān)文章:
1. html5 - css3scale和rotate同時(shí)使用轉(zhuǎn)換成matrix寫法該如何轉(zhuǎn)換?2. win10 python3.5 matplotlib使用報(bào)錯(cuò)3. php多任務(wù)倒計(jì)時(shí)求助4. css - 如何把一個(gè)視圖放在左浮動(dòng)定位的視圖的上面?5. javascript - jquery怎么讓a標(biāo)簽跳轉(zhuǎn)后保持tab的樣式6. MySQL的聯(lián)合查詢[union]有什么實(shí)際的用處7. javascript - 小demo:請(qǐng)教怎么做出類似于水滴不斷擴(kuò)張的效果?8. javascript - vue組件的重復(fù)調(diào)用9. python的正則怎么同時(shí)匹配兩個(gè)不同結(jié)果?10. javascript - axios請(qǐng)求回來的數(shù)據(jù)組件無法進(jìn)行綁定渲染
