获取
描述
integer/array problem.get(object parameters)
该方法允许根据给定参数检索问题。
此方法用于检索未解决的问题。如果有指定,也可以额外检索最近已解决的问题。用于确定“最近”时间范围的周期定义于 Administration →
General。
在该周期之前已解决的问题不会保留在 problem 表中。要检索更早之前已解决的问题,请使用 event.get 方法。
如果这些问题尚未被 housekeeper 移除,则该方法可能会返回已删除实体的问题。
任何类型的用户都可以使用此方法。在用户角色设置中可以撤销调用该方法的权限。更多信息请参见 User roles。
参数
(object) 定义所需输出的参数。
该方法支持以下参数。
| 参数 | 类型 | 描述 |
|---|---|---|
| eventids | ID/array | 仅返回具有给定 ID 的问题。 |
| groupids | ID/array | 仅返回由属于给定主机组的对象创建的问题。 |
| hostids | ID/array | 仅返回由属于给定主机的对象创建的问题。 |
| objectids | ID/array | 仅返回由给定对象创建的问题。 |
| source | integer | 仅返回给定类型的问题。 支持的事件类型列表请参见问题事件对象页面。 默认值:0 - 由触发器创建的问题。 |
| object | integer | 仅返回由给定类型对象创建的问题。 支持的对象类型列表请参见问题事件对象页面。 默认值:0 - 触发器。 |
| acknowledged | boolean | 如果设置为 true,则仅返回已确认的问题。 |
| action | integer | 仅返回已执行给定事件更新操作的问题。对于多个操作,使用任意可接受位图值之和作为位掩码(例如,34 表示确认并抑制事件)。 |
| action_userids | ID/array | 仅返回由具有给定 ID 的用户执行了问题事件更新操作的问题。 |
| suppressed | boolean | 如果设置为 true,则仅返回已被抑制的问题。 |
| symptom | boolean | 如果设置为 true,则仅返回症状问题事件。 |
| severities | integer/array | 仅返回具有给定事件严重性的的问题。仅当 object 为 trigger 时适用。 |
| evaltype | integer | 标签评估方法。 可能的值: 0 - (默认) And/Or; 2 - Or。 |
| tags | array | 仅返回具有给定标签的问题。 格式: [{"tag": "<tag>", "value": "<value>", "operator": "<operator>"}, ...]。空数组将返回所有问题。 可能的operator 值: 0 - (默认) 包含; 1 - 等于; 2 - 不包含; 3 - 不等于; 4 - 存在; 5 - 不存在。 |
| recent | boolean | 如果设置为 true,则仅返回最近已解决的问题(取决于 ok_period)。 |
| eventid_from | string | 仅返回 ID 大于或等于给定 ID 的问题。 |
| eventid_till | string | 仅返回 ID 小于或等于给定 ID 的问题。 |
| time_from | timestamp | 仅返回在给定时间之后或该时间创建的问题。 |
| time_till | timestamp | 仅返回在给定时间之前或该时间创建的问题。 |
| selectAcknowledges | query | 返回包含问题更新的 acknowledges 属性。问题更新按时间倒序排序。问题更新对象具有以下属性: acknowledgeid - (ID) 更新的 ID;userid - (ID) 更新事件的用户 ID;eventid - (ID) 被更新事件的 ID;clock - (timestamp) 事件更新的时间;message - (string) 消息文本;action - (integer)更新操作类型(参见 event.acknowledge);old_severity - (integer) 此更新操作之前的事件严重性;new_severity - (integer) 此更新操作之后的事件严重性;suppress_until - (timestamp) 事件将被抑制到的时间;taskid - (ID) 如果当前事件正在进行等级变更,则为任务 ID。支持 count。 |
| selectTags | query | 返回包含问题标签的 tags 属性。输出格式:[{"tag": "<tag>", "value": "<value>"}, ...]。 |
| selectSuppressionData | query | 返回 suppression_data 属性,其中包含活动维护和手动抑制的列表:maintenanceid - (ID) 维护的 ID;userid - (ID) 抑制该问题的用户 ID;suppress_until - (integer) 问题被抑制到的时间。 |
| filter | object | 仅返回与给定过滤器完全匹配的结果。 接受一个对象,其中键为属性名称,值为单个值或用于匹配的值数组。 不支持 text 数据类型 的属性。 |
| sortfield | string/array | 按给定属性对结果进行排序。 可能的值: eventid。 |
| countOutput | boolean | 这些参数在参考说明中描述。 |
| editable | boolean | |
| excludeSearch | boolean | |
| limit | integer | |
| output | query | |
| preservekeys | boolean | |
| search | object | |
| searchByAny | boolean | |
| searchWildcardsEnabled | boolean | |
| sortorder | string/array | |
| startSearch | boolean |
返回值
(integer/array) 返回之一:
- 对象数组;
- 如果使用了
countOutput参数,则为检索到的对象的数量。
示例
检索触发器问题事件
检索触发器“15112”的最近事件。
请求:
{
"jsonrpc": "2.0",
"method": "problem.get",
"params": {
"output": "extend",
"selectAcknowledges": "extend",
"selectTags": "extend",
"selectSuppressionData": "extend",
"objectids": "15112",
"recent": true,
"sortfield": ["eventid"],
"sortorder": "DESC"
},
"id": 1
}
响应:
{
"jsonrpc": "2.0",
"result": [
{
"eventid": "1245463",
"source": "0",
"object": "0",
"objectid": "15112",
"clock": "1472457242",
"ns": "209442442",
"r_eventid": "1245468",
"r_clock": "1472457285",
"r_ns": "125644870",
"correlationid": "0",
"userid": "1",
"name": "localhost 上的 Zabbix agent 已有 5 分钟无法访问",
"acknowledged": "1",
"severity": "3",
"cause_eventid": "0",
"opdata": "",
"acknowledges": [
{
"acknowledgeid": "14443",
"userid": "1",
"eventid": "1245463",
"clock": "1472457281",
"message": "问题已解决",
"action": "6",
"old_severity": "0",
"new_severity": "0",
"suppress_until": "1472511600",
"taskid": "0"
}
],
"suppression_data": [
{
"maintenanceid": "15",
"suppress_until": "1472511600",
"userid": "0"
}
],
"suppressed": "1",
"tags": [
{
"tag": "test-tag",
"value": "test-value"
}
]
}
],
"id": 1
}
检索指定用户确认的问题
检索由 ID为10 的用户确认的问题
请求:
{
"jsonrpc": "2.0",
"method": "problem.get",
"params": {
"output": "extend",
"action": 2,
"action_userids": [10],
"selectAcknowledges": ["userid", "action"],
"sortfield": ["eventid"],
"sortorder": "DESC"
},
"id": 1
}
响应:
{
"jsonrpc": "2.0",
"result": [{
"eventid": "1248566",
"source": "0",
"object": "0",
"objectid": "15142",
"clock": "1472457242",
"ns": "209442442",
"r_eventid": "1245468",
"r_clock": "1472457285",
"r_ns": "125644870",
"correlationid": "0",
"userid": "10",
"name": "Zabbix agent on localhost is unreachable for 5 minutes",
"acknowledged": "1",
"severity": "3",
"cause_eventid": "0",
"opdata": "",
"acknowledges": [{
"userid": "10",
"action": "2"
}],
"suppressed": "0"
}],
"id": 1
}
另请参阅
来源
ui/include/classes/api/services/CProblem.php 中的 CEvent::get()。