Vous consultez la documentation d'Apigee Edge.
Consultez la
documentation Apigee X. en savoir plus
Utilisez les API décrites ci-dessous pour obtenir les métriques de surveillance des API. Les métriques sont les valeurs de données agrégées par API Monitoring à partir des données brutes contenues dans les journaux de surveillance de l'API.
Les sections suivantes décrivent comment gérer les métriques à l'aide de l'API.
- API de métriques
- Obtenir des informations sur les pannes
- Capturer les métriques de trafic et de latence
- Enregistrer des métriques pour les alertes
Consultez API de métriques pour plus d'informations sur l'API de métriques.
Pour plus d'informations sur les options cURL utilisées dans ces exemples, consultez Utiliser cURL.
API de métriques
L'URL de base que vous utilisez pour envoyer une requête GET à l'API de métriques est la suivante:
https://apimonitoring.enterprise.apigee.com/metrics/resource
Où resource correspond à une métrique spécifique. Le tableau suivant répertorie les ressources de métriques:
Ressource | Description |
/traffic
|
Obtenez des métriques sur le trafic. Spécifiez des filtres tels que le nom du proxy, l'intervalle, la période, la cible, le code d'état et bien d'autres. |
/latency
|
Obtenir des métriques de latence pour les requêtes
vers Edge et vers les cibles principales. Spécifiez des filtres tels que le nom du proxy, l'intervalle, la cible, le code d'état, etc. |
/targets
|
Obtenez tous les domaines cibles pour une organisation et un environnement spécifiques. |
/alerthistory
|
Obtenez des métriques sur l'historique des alertes pour une organisation et une période spécifiques. |
/alertinstance/instanceid
|
Obtenez des métriques de l'historique des alertes pour l'ID d'instance d'alerte spécifique. |
/alertsummary
|
Obtenez le nombre total d'alertes pour une organisation et une fenêtre temporelle. |
/faultcodenames
|
Obtenir tous les noms de codes d'erreur. |
/faultcodes
|
Obtenez des codes d’erreur. |
/faultcodecategories
|
Obtenir les catégories de code d'erreur. |
/faultcodesubcategories
|
Obtenir des sous-catégories de code d'erreur. |
/faultcodedetails
|
Obtenez tous les codes d'erreur avec les détails. |
Obtenir des informations sur les pannes
Les ressources /fault*
renvoient toutes des métadonnées sur les erreurs possibles sur Edge.
Par exemple, pour voir la liste de toutes les catégories d'erreurs possibles:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/faultcodecategories" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Définissez $ACCESS_TOKEN
sur votre jeton d'accès OAuth 2.0, comme décrit dans la section Obtenir un jeton d'accès OAuth 2.0.
La réponse apparaît sous la forme:
{
"faultCodeCategories":[
"","API Protocol","Developer/App","Extension Policy","Gateway",
"Mediation Policy","Mint","Security Policy","Sense","Traffic Mgmt Policy"
]
}
Vous pouvez ensuite déterminer la liste des codes d'erreur pour la catégorie API Protocol
:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/faultcodes?faultCodeCategory=API Protocol" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Pour plus d'options, consultez l'API Metrics.
Capturer les métriques de trafic et de latence
L'API de métriques comporte des filtres que vous pouvez appliquer à l'API pour spécifier des plages de temps personnalisées, des proxys, des régions, des environnements et d'autres filtres pour les métriques calculées. Par exemple, pour afficher la métrique de transactions par seconde (tps) toutes les 10 minutes de l'heure précédente pour tous les environnements:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/traffic?from=-1h&to=now&select=tps&interval=10m&groupBy=env&org=myorg" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Définissez $ACCESS_TOKEN
sur votre jeton d'accès OAuth 2.0, comme décrit dans la section Obtenir un jeton d'accès OAuth 2.0.
Cet appel renvoie les résultats sous la forme:
{
"results":[
{
"series":[
{
"name":"proxy",
"tags":
{
"env":"prod",
"intervalSeconds":"60",
"org":"myorg",
"region":"myregion"
},
"columns":["time","tps"],
"values":[
["2018-08-15T13:10:00Z",5.03],
["2018-08-15T13:20:00Z",5.01],
["2018-08-15T13:30:00Z",5.81],
["2018-08-15T13:40:00Z",5.95],
…
]
},
…
}
}]
}
Notez que la propriété columns
spécifie le format de values
. La propriété values
contient le nombre de tps calculé toutes les 10 minutes pour l'intervalle précédent de 10 minutes.
Le paramètre de requête interval
définit la fréquence à laquelle la métrique est enregistrée dans les résultats et la fenêtre d'échantillonnage pour la valeur dans les résultats. Dans l'exemple ci-dessus, la métrique est calculée sur les 10 dernières minutes et écrite dans les résultats toutes les 10 minutes.
Utilisez les paramètres de requête from
et to
pour spécifier une plage de temps au format ISO.
La durée maximale spécifiée par from
et to
est de 24 heures.
Le format de la date peut être soit:
yyyy-mm-ddThh:mm:ssZ
yyyy-mm-ddThh:mm:ss+00:00
Exemple :
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/traffic?from=2018-08-13T14%3A04%3A00Z&to=2018-08-13T14%3A10%3A00Z&select=tps&interval=1m&groupBy=env&org=myorg&proxy=PublicAPI" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Vous pouvez également utiliser les paramètres de requête from
et to
pour spécifier une période relative, par exemple pour la dernière heure:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/traffic?from=-1h&to=now&select=tps&interval=1m&groupBy=env&org=myorg&proxy=PublicAPI" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Une autre option consiste à utiliser le paramètre de requête proxy
pour afficher le nombre de transactions par seconde (tps) pour un seul proxy:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/traffic?from=-1h&to=now&select=tps&interval=1m&groupBy=env&org=myorg&proxy=PublicAPI" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Pour les métriques de latence, spécifiez un grand nombre de critères identiques à ceux des métriques de trafic. Toutefois, pour la ressource /latency
:
- Vous devez spécifier le paramètre de requête
percentile
comme50
,90
,95
ou99
. Par exemple, si vous spécifiez90
, l'API renvoie la valeur de latence totale de la réponse au 90e centile. - La valeur
windowsize
est fixée à une minute.
Par exemple, pour afficher les métriques de la latence totale au 90e centile pour une fenêtre d'une minute:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/latency?percentile=90&select=totalLatency&from=-1h&to=now&interval=5m&windowsize=1m&groupBy=org,env,region&org=myorg" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Pour plus d'options, consultez API Metrics.
Capturer les métriques pour les alertes
L'API de métriques renvoie des métriques pour toutes les alertes, pour une alerte spécifique ou pour un résumé d'alerte. Par exemple, pour obtenir l'historique des alertes d'une organisation pour la dernière heure:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/alerthistory?org=myorg&from=-1h&to=now" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Définissez $ACCESS_TOKEN
sur votre jeton d'accès OAuth 2.0, comme décrit dans la section Obtenir un jeton d'accès OAuth 2.0.
Cet appel d'API renvoie une réponse au format suivant:
[
{
"id":"983c4c7a-c301-4697-95cc-9a7c53e05fac",
"organization":"myorg",
"environment":"prod",
"name":"Public Api 5xx error rate",
"type":"Alert",
"source":"https://www.apigee.net/sonar",
"raw_payload":"
{
\"reportUUID\":\"\",
\"reportEnabled\":false,
\"organization\":\"myorg\",
\"name\":\"Public Api 5xx error rate\",
\"self\":\"/alerts/95cc9ef4-345f-11e8-9fd3-12774584e062\",
\"description\":\"\",
\"conditions\":[
{
\"comparator\":\"\u003e\",
\"metric\":\"rate\",
\"durationSeconds\":3600,
\"name\":\"\",
\"description\":\"\",
\"threshold\":0.01,
\"dimensions\":
{
\"proxy\":\"myAPI\",
\"org\":\"myorg\",
\"env\":\"prod\",
\"region\":\"myRegion\",
\"statusCode\":\"5xx\"
}
}],
\"uuid\":\"95cc9ef4-345f-11e8-9fd3-12774584e062\",
\"playbook\":\"This is a test alert.\"
}",
"time":"2018-08-14T12:45:28Z"
},
…
]
Vous pouvez ensuite utiliser id
dans le tableau renvoyé pour obtenir des informations sur une alerte spécifique:
curl -X GET \ "https://apimonitoring.enterprise.apigee.com/metrics/alertinstance/983c4c7a-c301-4697-95cc-9a7c53e05fac" \ -H "accept: application/json" \ -H "Authorization: Bearer $ACCESS_TOKEN"
Pour plus d'options, consultez l'API Metrics.