获取

描述

integer/array history.get(object parameters)

该方法允许根据指定的参数查询历史数据。

如果管家尚未清理已删除实体的历史数据,则此方法可以返回该数据。

任何类型的用户都可以使用此方法。可以在用户角色设置中撤销调用该方法的权限。有关更多信息,请参阅用户角色

参数

(object) 定义所需输出的参数。

该方法支持以下参数。

Parameter Type Description
history integer 返回的历史数据对象类型。

可能的值:
0 - 数值浮点;
1 - 字符;
2 - 日志;
3 - (默认) 数值无符号;
4 - 文本;
5 - 二进制。
hostids ID/array 仅返回来自指定主机的历史数据。
itemids ID/array 仅返回来自指定监控项的历史数据。
time_from timestamp 仅返回在指定时间之后或等于该时间接收的值。
time_till timestamp 仅返回在指定时间之前或等于该时间接收的值。
sortfield string/array 按指定属性对结果排序。

可能的值:itemidclockns
search object 返回与给定模式匹配的结果(不区分大小写)。

接受一个对象,其中键为属性名,值为要搜索的字符串。如果未提供其他选项,将执行 LIKE "%…%" 搜索。

history 设置为 6(JSON)时,不支持按 value 搜索。
countOutput boolean 这些参数在参考说明中有描述。
editable boolean
excludeSearch boolean
filter object
limit integer
output query
search object
searchByAny boolean
searchWildcardsEnabled boolean
sortorder string/array
startSearch boolean

返回值

返回 (integer/array) 其中之一:

  • 一个对象的数组;
  • 如果使用了 countOutput 参数,则为检索到的对象的数量。

示例

检索监控项的历史数据

返回从一个 numeric(float) 监控项收到的10个最新值。

请求:

{
    "jsonrpc": "2.0",
    "method": "history.get",
    "params": {
        "output": "extend",
        "history": 0,
        "itemids": "23296",
        "sortfield": "clock",
        "sortorder": "DESC",
        "limit": 10
    },
    "id": 1
}

响应:

{
    "jsonrpc": "2.0",
    "result": [
        {
            "itemid": "23296",
            "clock": "1351090996",
            "value": "0.085",
            "ns": "563157632"
        },
        {
            "itemid": "23296",
            "clock": "1351090936",
            "value": "0.16",
            "ns": "549216402"
        },
        {
            "itemid": "23296",
            "clock": "1351090876",
            "value": "0.18",
            "ns": "537418114"
        },
        {
            "itemid": "23296",
            "clock": "1351090816",
            "value": "0.21",
            "ns": "522659528"
        },
        {
            "itemid": "23296",
            "clock": "1351090756",
            "value": "0.215",
            "ns": "507809457"
        },
        {
            "itemid": "23296",
            "clock": "1351090696",
            "value": "0.255",
            "ns": "495509699"
        },
        {
            "itemid": "23296",
            "clock": "1351090636",
            "value": "0.36",
            "ns": "477708209"
        },
        {
            "itemid": "23296",
            "clock": "1351090576",
            "value": "0.375",
            "ns": "463251343"
        },
        {
            "itemid": "23296",
            "clock": "1351090516",
            "value": "0.315",
            "ns": "447947017"
        },
        {
            "itemid": "23296",
            "clock": "1351090456",
            "value": "0.275",
            "ns": "435307141"
        }
    ],
    "id": 1
}

源码

CHistory::get() in ui/include/classes/api/services/CHistory.php.