全部產品
Search
文件中心

Function Compute:函數執行個體生命週期回調

更新時間:Jul 06, 2024

本文介紹Custom Runtime實現函數執行個體生命週期回調的方法。

回調方法

當您實現並配置函數執行個體生命週期回調後,Function Compute將在相關執行個體生命週期事件發生時調用對應的回調程式。函數執行個體生命週期涉及Initializer、PreFreeze和PreStop三種回調。更多資訊,請參見函數執行個體生命週期回調

Path輸入請求期望的響應
(可選)POST /initialize

請求體:無。

要求標頭:Common Request Headers。具體資訊,請參見Function Compute公用要求標頭

響應體:函數Initializer的傳回值。
StatusCode
  • 2xx:成功狀態。
  • 非2xx:失敗狀態。
Python語言中關於initialize的範例程式碼如下:
@app.route('/initialize', methods=['POST'])
def init_invoke():
  rid = request.headers.get(x-fc-request-id)
  print("FC Initialize Start RequestId: " + rid)
  # do your things
  print("FC Initialize End RequestId: " + rid)
  return "OK"
Python語言中函數執行報錯的範例程式碼如下:
@app.route('/initialize', methods=['POST'])
def init():
    raise Exception("hahaha")
    return "OK", 200, []
@app.route('/initialize', methods=['POST'])
def init():
    return "OK", 404, []
(可選)GET /pre-freeze響應體:函數PreFreeze的傳回值。
StatusCode
  • 2xx:成功狀態。
  • 非2xx:失敗狀態。
(可選)GET /pre-stop響應體:函數PreStop的傳回值。
StatusCode
  • 2xx:成功狀態。
  • 非2xx:失敗狀態。
如果您想在Custom Runtime中使用Initializer回調方法,您只需在您的HTTP Server中實現Path為/initialize和Method為POST的對應邏輯即可。範例程式碼,請參見上表中關於initialize的範例程式碼。
重要 如果建立的函數不設定Initializer,就無需實現/initialize。此時,即使HTTP Server實現了/initialize,代碼中的/initialize邏輯也無法被調用執行。

PreFreeze和PreStop回調方法的使用,同Initializer回調方法。

回調錯誤碼

錯誤碼ID解釋說明
400
  • 函數Initializer回調失敗返回400或404,不會重新發送請求,但系統會繼續重試直到調用成功為止。
  • 函數PreFreeze和PreStop回調失敗返回400或404,不會影響函數執行個體的冷凍和停止。
404
500Function Compute重啟執行個體。