Lambda
Lambda 是一種 serverless 的服務, 也就是不需要考慮實體 server 的配置以及相關的維運, 因此開發人員可以專注於商業邏輯的開發,Scaling Out
當同一時間內的請求數量增加的很快時, Lambda 會自己做 Scaling out, 也就是複製另一個容器去處理這些突然增加的請求, 因此對開發人員來說, 就不需要去考慮負載平衡的問題Version Control
如果沒有特別建立版本, Lambda只會替我們保留最後一版($Latest)這是個非常好用的功能, 因為實務上同一個 Lambda Function 我們可能會需要同時存在多個版本, 正式版, 測試版,等等,
在 Lambda 上只要幾個步驟, 我們就能發布一個版本
Action > Publish new version
(每次修改 Lambda 都允許我們對此發布"一個"版本, 但發布出來的版本無法再被修改)
每個版本都有它自己的 ARN, 搭配建立 Alias Name 我們可以讓 API Gateway去串接特定名稱的Lambda ARN, 而去呼叫某特定版本的 Lambda Function
當有新版本出現時, 我們也測試過一切都沒問題後, 只要將原本 Alias 名稱指到最新版, API Gateway 就能夠呼叫到最新版
Qualified ARN
Qualified ARN 就是ARN後面會再帶一個版本
ARN - arn:aws:lambda:us-east-1:5234234220:function:ProcessVideo:2
Alias
Lambda 允許我們替每個版本建立Alias名稱(如上所述)
除此之外, 我們也可以在建立Alias的時候設定分流
在 Addition Version 這邊, 我們可以指定將部分的流量轉到特定的版本上
(可以用在做A&B Testing)
也就是說, 假設我呼叫底下ARN的Lambda時
arn:aws:lambda:us-east-1:5234234220:function:ProcessVideo:proc
實際上, 會有30%的請求跑到version 1那邊處理
arn:aws:lambda:us-east-1:5234234220:function:ProcessVideo:1
留言
張貼留言