Get Link’s Metrics History
Retrieves link’s metric history.
Request
Path parameters
Parameter | Type | Description |
---|---|---|
id |
String |
The ID of a link whose metrics history should be retrieved. |
Query parameters
Parameter | Type | Description |
---|---|---|
metrics |
String |
A comma-separated list of metrics to be retrieved. |
from |
String |
A lower-bound timestamp of metrics' values. |
downsample |
String |
A down-sampling parameter. For example, |
timezone |
String |
A timezone of metrics' values. For example, |
to |
String |
An upper-bound timestamp of metrics' values. |
Response
Returns an array of requested metrics. Each metric contains the following fields:
Field | Type | Description |
---|---|---|
metric |
String |
Metric name. |
tags.entity |
String |
The ID of the entity prefixed by the type of the entity. The format is |
aggregateTags |
Array |
|
dps |
Array<DataPoint> |
An array of data points. Each data point is represented by an array that contains two values. The first one is a timestamp, the second one is value. |
To get all available metrics for a link, use the Get Link Stat Metrics method. |
Example
Request
-
Bash
-
JavaScript
-
NodeJS
-
Python
login=<...>
password=<...>
saymon_hostname=<...>
link_id=<...>
url=https://$saymon_hostname/node/api/links/$link_id/history
curl -X GET $url -u $login:$password -G \
--data-urlencode "metrics=packetsTransmitted,packetsReceived" \
--data-urlencode "from=1580906276000"
let login = <...>
let password = <...>
let saymonHostname = <...>
let linkId = <...>
let queryParams = "metrics=packetsTransmitted,packetsReceived" +
"&" + "from=1580906276000";
let path = "/node/api/links/" + linkId + "/history" + "?" + queryParams;
let auth = "Basic " + btoa(login + ":" + password);
let headers = new Headers();
headers.append("Authorization", auth);
let requestOptions = {
method: "GET",
headers: headers
};
fetch(saymonHostname + path, requestOptions)
.then(response => response.text())
.then(result => console.log(result))
.catch(error => console.log("error", error));
const http = require("http");
const querystring = require("querystring");
let login = <...>
let password = <...>
let saymonHostname = <...>
let linkId = <...>
let queryParams = querystring.stringify({
metrics : "packetsTransmitted,packetsReceived",
from : "1580906276000"
});
let path = "/node/api/links/" + linkId + "/history" + "?" + queryParams;
let auth = "Basic " + Buffer.from(login + ":" + password).toString("base64");
let options = {
"method": "GET",
"hostname": saymonHostname,
"headers": {
"Authorization": auth
},
"path": path
};
let req = http.request(options, function (res) {
let chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function (chunk) {
let body = Buffer.concat(chunks);
console.log(body.toString());
});
res.on("error", function (error) {
console.error(error);
});
});
req.end();
import requests
login = <...>
password = <...>
saymon_hostname = <...>
link_id = <...>
url = "https://" + saymon_hostname + "/node/api/links/" + \
link_id + "/history"
params = {
"metrics": "packetsTransmitted,packetsReceived",
"from": "1580906276000"
}
response = requests.request("GET", url, auth=(login, password), params=params)
print(response.text)
Response
[
{
"metric": "packetsTransmitted",
"tags": {
"entity": "link5e7df795f988c426bb37215e"
},
"aggregateTags": [],
"dps": [
[
1662121832050,
4
],
[
1662121839385,
4
]
...
]
},
{
"metric": "packetsReceived",
"tags": {
"entity": "link5e7df795f988c426bb37215e"
},
"aggregateTags": [],
"dps": [
[
1662121832050,
4
],
[
1662121839385,
4
]
...
]
}
]