云函數(shù)Web Function支持原生WebSocket協(xié)議后,受到了眾多開發(fā)者的關注,與此同時,我們也收到了許多疑問和反饋。本篇文章將大家關注的點總結了八大問題并進行了一一解答,希望可以幫助您更好理解和使用云函數(shù)的WebSocket功能。
01.
事件函數(shù)、Web函數(shù)、WebSocket之間的關系?
目前函數(shù)支持了不同類型的函數(shù),寫法和支持功能上都有一定區(qū)別,幾種函數(shù)類型關系如圖:
由于接收的觸發(fā)源類型不同,云函數(shù)支持了Web函數(shù)與事件函數(shù)為兩大類型,Web函數(shù)下又支持不同的Web協(xié)議,可以根據(jù)實際業(yè)務選擇對應的函數(shù)類型。
02.
云函數(shù)上使用WebSocket,代碼究竟應該怎么寫?
對于傳統(tǒng)開發(fā)者而言,遇到的最大問題是不知道如何在云端寫函數(shù),Web函數(shù)提供了最原生的開發(fā)方式,以WebSocket服務器代碼開發(fā)為例,除了需要指定監(jiān)聽端口外,本地業(yè)務代碼和云端業(yè)務代碼并無其它區(qū)別,直接部署上傳即可,示例如下:
scf_bootstrap示例:
#!/bin/bash
/var/lang/node12/bin/node app.js
03.
已部署為http&https協(xié)議的Web函數(shù),能否升級為WebSocket協(xié)議?
目前還不支持函數(shù)協(xié)議的直接轉換,建議采用創(chuàng)建新函數(shù)的方式體驗WebSocket的功能。
04.
在WebSocket場景下,函數(shù)的超時時間是如何定義的?
WebSocket的場景下,超時時間分為三部分,介紹如下:
·初始化超時時間:函數(shù)初始化階段包括準備函數(shù)代碼、準備鏡像、準備層等相關資源以及執(zhí)行函數(shù)主流程代碼,可選值范圍為3-300秒,鏡像部署函數(shù)默認90秒,其他函數(shù)默認60秒。
·執(zhí)行超時時間:函數(shù)的最長運行時間,對WS協(xié)議而言,此處指從發(fā)起連接請求到連接斷開,完成一次調(diào)用的時間,如果您的業(yè)務場景對WS有長時間保持連接的要求,建議調(diào)大該時間。
·WS空閑超時時間:指WS的空閑等待時間,可選范圍1-600秒。
05.
對于WebSocket函數(shù),應該如何查看運行日志?常見狀態(tài)碼與錯誤原因?
日志查看的方式與事件函數(shù)相同,您可以通過console.log()、print()等通用方式完成日志打印,并在控制臺查看到運行日志。
狀態(tài)碼說明:更詳細的函數(shù)狀態(tài)碼可見云函數(shù)狀態(tài)碼列表。
云函數(shù)狀態(tài)碼表:https://cloud.tencent.com/document/product/583/42611
06.
WebSocket的常見使用場景如聊天室,需要實現(xiàn)連接信息的注冊存儲,在云函數(shù)架構下該如何實現(xiàn)?
云函數(shù)為單實例單并發(fā),對于聊天室場景,不同用戶的請求訪問后臺服務時,云函數(shù)會根據(jù)實際請求數(shù)量進行擴縮容調(diào)整后臺實例數(shù),不同實例之間,需要新增消息隊列/Redis作為中間件層,實現(xiàn)多Server之間的通訊,從而實現(xiàn)消息的精準廣播:
1.建立連接模塊,函數(shù)通過WS請求進行連接信息的篩選,并記錄到消息隊列/Redis中完成注冊:
2.消息傳輸模塊,云函數(shù)將發(fā)送請求的請求ID,發(fā)送給中間件,根據(jù)ID決定消息的廣播或指定用戶發(fā)送,網(wǎng)關側透傳請求,不做特殊業(yè)務邏輯處理;
3.消息清理模塊,用戶斷開連接,函數(shù)同步清理中間件層的注冊消息
07.
Http協(xié)議和WS能否混用?期望用戶通過Http訪問,但使用WS來轉發(fā)
對于Web函數(shù),這種場景是可以實現(xiàn)的,但架構上無法通過單一函數(shù)管理,而是需要使用兩個函數(shù),并在中間通過一個消息隊列/Redis作為中間件來連接,參考架構如圖:
08.
WebSocket往往需要一直保持心跳,這里如何計費?
WebSocket的計費項與事件函數(shù)相同,各個計費項說明如下:
·Web函數(shù)調(diào)用次數(shù):按照每次WS建立連接收費,連接后續(xù)的心跳次數(shù)不做計費;(Web函數(shù)調(diào)用費用即將進行優(yōu)化,敬請期待)
·函數(shù)資源量GBs:按照連接從WS建立到斷開的總時間統(tǒng)計函數(shù)運行時長,設置合理的超時時間可以有效節(jié)省費用;
·外網(wǎng)出流量:函數(shù)對外訪問的流量費用,與現(xiàn)有函數(shù)統(tǒng)計方式相同。