查看 Apigee Edge 說明文件。
前往
Apigee X說明文件。 資訊
用於建立及管理異常快訊和收集異常指標指標的 API,大多與固定快訊相同。下列 Alert API 的運作方式與固定和異常快訊有關:
不過,部分 API 的額外屬性可用於支援異常快訊,包括:
設定 $ACCESS_TOKEN
下方顯示的所有 API 呼叫都會透過名為 $ACCESS_TOKEN 的環境變數傳送憑證。
按照下列說明將 $ACCESS_TOKEN 設為 OAuth 2.0 存取權杖
取得 OAuth 2.0 存取權杖。
如要瞭解這些範例中使用的 cURL 選項,請參閱
使用 cURL。
取得快訊
根據預設,「取得快訊」 API 會傳回所有已定義快訊的相關資訊。 這個 API 現在會使用查詢參數來篩選結果:
enabled- 如果true指定只傳回已啟用的快訊, 預設值為false。alertType:指定要傳回的快訊類型。允許的值為runtime。 預設值為cert。alertSubType- 指定要傳回的快訊子類型。系統不會設定預設值。 也就是傳回所有快訊子類型指定anomaly即可傳回異常快訊。
舉例來說,使用下列 API 呼叫,只傳回下列機構的快訊:
myorg:
curl -H "Authorization: Bearer $ACCESS_TOKEN" \ 'https://apimonitoring.enterprise.apigee.com/alerts?org=myorg&enabled=true'
以下呼叫只會傳回已啟用和已停用的異常快訊:
curl -H "Authorization: Bearer $ACCESS_TOKEN" \ 'https://apimonitoring.enterprise.apigee.com/alerts?org=myorg&alertType=runtime&alertSubType=anomaly'
建立或更新異常快訊
使用相同的 API 建立 或更新 發生異常快訊要建立或更新的 API 呼叫主體 異常快訊與已修正快訊的相同,但有以下變更:
您必須新增下列屬性,指明快訊是異常快訊:
"alertType": "runtime" "alertSubType": "anomaly"
這些屬性的預設值如下:
"alertType": "runtime" "alertSubType": "fixed"
在
conditions陣列中:metrics屬性僅接受下列值:count- 針對 HTTP 錯誤數量發出快訊。totalLatency- 針對延遲時間提高快訊。
threshold屬性採用字串而非數字。支援的值包括:slight、moderate和severe。- 不支援
durationSeconds和comparator屬性。
在
conditions陣列的dimensions元素中:- 您必須將
proxy屬性的值設為ALL。 statusCode屬性僅支援4xx, 503, 504, and 5xx的值。developerApp、collection、faultCodeCategory、 不支援faultCodeSubCategory、faultCodeName屬性。
- 您必須將
reportEnabled屬性不支援異常狀況快訊。
下列 API 呼叫範例會建立在 5xx 狀態碼時觸發的異常快訊 在所有區域的實際工作環境中,所有 API Proxy 的速率都是中等。通知 快訊觸發時,會傳送至指定的電子郵件地址:
curl 'https://apimonitoring.enterprise.apigee.com/alerts' \
-X POST \
-H 'Accept: application/json, text/plain, */*' -H "Content-Type: application/json" \
-H "Authorization: Bearer $ACCESS_TOKEN" \
-d '{
"organization":"myorg",
"name":"5xx Anomaly Alert",
"description":"My 5xx alert",
"environment":"prod",
"enabled":true,
"alertType": "runtime",
"alertSubType": "anomaly",
"conditions":[
{
"description":"",
"dimensions":{
"org":"myorg",
"env":"prod",
"proxy":"ALL",
"region":"ANY",
"statusCode":"5xx"
},
"metric":"count",
"threshold": "moderate"
}
],
"notifications":[{
"channel":"email",
"destination":"ops@acme.com"
}],
"playbook":"http://acme.com/myplaybook.html",
"throttleIntervalSeconds":3600
}'
使用事件 API 搭配異常狀況
使用「/metrics/events」
取得 API,取得指定時間間隔的機構中所有事件。事件清單包括
由 Edge 偵測到的異常狀況以及所有觸發的快訊。快訊可能包含固定快訊和異常狀況快訊。
根據預設,API 會傳回前一小時的所有事件。使用 from 和
to 查詢參數,用於指定不同的時間長度。from和
to 查詢參數值,用於指定不同的時間長度。
舉例來說,下列 API 呼叫會傳回 myorg 機構中的所有事件
過去 12 小時內的資料
curl -H "Authorization: Bearer $ACCESS_TOKEN" \ "https://apimonitoring.enterprise.apigee.com/metrics/events?org=myorg&from=-12h&to=now"
按照下列說明將 $ACCESS_TOKEN 設為 OAuth 2.0 存取權杖
取得 OAuth 2.0 存取權杖。如需深入瞭解
範例使用的 cURL 選項,請參閱「使用 cURL」一節。
下一個呼叫會傳回過去 24 小時內中等門檻的所有異常事件:
curl -H "Authorization: Bearer $ACCESS_TOKEN" \ "https://apimonitoring.enterprise.apigee.com/metrics/events?org=myorg&type=anomaly&threshold=moderate&from=-24h&to=now"
這個 API 只需要 org 查詢參數。使用查詢參數
在 /metrics/events 的 API 文件所述,
這個 API 支援下列異常偵測選項:
| 名稱 | 說明 | 預設 |
|---|---|---|
threshold
|
按照指定的門檻篩選事件: 只有在設定 |
所有嚴重程度 |
type
|
按照指定類型篩選事件:alert 或 anomaly。
使用逗號分隔清單指定多個值。
|
所有類型 |