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è)請求會(huì)被掛起很長一段時(shí)間把?一般這種地方應(yīng)該怎么處理?因?yàn)橹恍枰猻et而不需要返回結(jié)果給用戶,所以收到請求之后就直接res.end()來關(guān)閉連接可以不?
問題解答
回答1:這取決于你是否希望這個(gè) HTTP 請求的返回結(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 請求。如果你們希望終端用戶得到這個(gè)確切的提交結(jié)果,那需要考慮交互層面了,設(shè)計(jì)良好的交互效果,2-6秒的等待,用戶體驗(yàn)不會(huì)很差(指AJAX請求場景下,打開新頁面場景下還是慎重)。寫三次redis幾乎是不花時(shí)間,比起 HTTP 請求本身的鏈路延遲根本不算什么。
具體業(yè)務(wù)場景還要具體分析。碰到特別耗時(shí)的操作,前端提交操作請求后輪訓(xùn)結(jié)果也不失為一種解決方案。
回答2:看頁面顯示和數(shù)據(jù)庫操作結(jié)果有沒有相關(guān)性。如果有相關(guān)性,可以等待數(shù)據(jù)庫操作結(jié)束之后返回。也可以做成異步隊(duì)列的方式直接返回,成功后在推送結(jié)果。最終怎么樣,還是看你需求。
相關(guān)文章:
1. 我在centos容器里安裝docker,也就是在容器里安裝容器,報(bào)錯(cuò)了?2. docker-compose中volumes的問題3. 在windows下安裝docker Toolbox 啟動(dòng)Docker Quickstart Terminal 失敗!4. docker-machine添加一個(gè)已有的docker主機(jī)問題5. golang - 用IDE看docker源碼時(shí)的小問題6. docker不顯示端口映射呢?7. javascript - 連續(xù)點(diǎn)擊觸發(fā)mouseleave事件8. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””9. docker內(nèi)創(chuàng)建jenkins訪問另一個(gè)容器下的服務(wù)器問題10. mac里的docker如何命令行開啟呢?

網(wǎng)公網(wǎng)安備