javascript - Nodejs服務器中 應該何時res.end()呢?
問題描述
有這樣的一個場景 ’/blog’ 路由下要處理用戶提交的數據假設要把三份數據存儲給三個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包裝的好看一些 但是在最后一個回調中res.end()來關閉連接,是不是存在問題?這個請求會被掛起很長一段時間把?一般這種地方應該怎么處理?因為只需要set而不需要返回結果給用戶,所以收到請求之后就直接res.end()來關閉連接可以不?
問題解答
回答1:這取決于你是否希望這個 HTTP 請求的返回結果與數據庫操作的結果有關聯性,以及用戶交互設計是否容忍這個操作所花費的時間。
你在設計這個 ’/blog’ 接口時,需要明確指明 HTTP 返回 200 意味著什么。如果你們的業務場景只關心數據交付到后端,不關心后端是否正確存儲到數據庫,那肯定可以直接結束掉 HTTP 請求。如果你們希望終端用戶得到這個確切的提交結果,那需要考慮交互層面了,設計良好的交互效果,2-6秒的等待,用戶體驗不會很差(指AJAX請求場景下,打開新頁面場景下還是慎重)。寫三次redis幾乎是不花時間,比起 HTTP 請求本身的鏈路延遲根本不算什么。
具體業務場景還要具體分析。碰到特別耗時的操作,前端提交操作請求后輪訓結果也不失為一種解決方案。
回答2:看頁面顯示和數據庫操作結果有沒有相關性。如果有相關性,可以等待數據庫操作結束之后返回。也可以做成異步隊列的方式直接返回,成功后在推送結果。最終怎么樣,還是看你需求。
相關文章:
1. Python爬蟲如何爬取span和span中間的內容并分別存入字典里?2. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處3. mysql 查詢身份證號字段值有效的數據4. 視頻文件不能播放,怎么辦?5. flask - python web中如何共享登錄狀態?6. 請教使用PDO連接MSSQL數據庫插入是亂碼問題?7. python - 數據與循環次數對應不上8. 黑客 - Python模塊安全權限9. mysql - 把一個表中的數據count更新到另一個表里?10. node.js - nodejs開發中常用的連接mysql的庫
