查询
描述
integer/array hostprototype.get(object parameters)
该方法允许根据给定的参数获取主机原型记录。
该方法适用于管理员和超级管理员用户类型。可以在用户角色设置中撤销调用该方法的权限。有关详细信息,参阅用户角色。
参数
(object)
定义所需输出的参数
该方法支持以下属性:
参数 | 类型 | 描述 |
---|---|---|
hostids | 字符串/数组 | 仅返回给定ID的主机原型。 |
discoveryids | 字符串/数组 | 仅返回属于给定LLD规则的主机原型。 |
inherited | 布尔值 | 如果设置为true 仅返回从模板中继承的监控项。 |
selectDiscoveryRule | 查询 | 返回主机原型归属的LLD规则的自动发现规则 属性。 |
selectInterfaces | 查询 | 返回主机原型自定义接口中 接口 属性。 |
selectGroupLinks | 查询 | 返回主机原型关联的组链接的组链接属性。 |
selectGroupPrototypes | 查询 | 返回主机原型关联的组原型的 组原型属性。 |
selectMacros | 查询 | 返回主机原型宏的 宏属性。 |
selectParentHost | 查询 | 返回主机原型所属的主机的父主机属性。 |
selectTags | query | 返回主机原型标签的 标签属性。 |
selectTemplates | 查询 | 返回主机原型链接的模板的模板 属性。 支持 count 。 |
sortfield | 字符串/数组 | 按给定属性,对结果进行排序 可能的值有: hostid , host , name 和 status . |
countOutput | 布尔值 | 这个参数对常用Zabbix API信息 页面中所有 get 方法都适用。 |
editable | 布尔值 | |
excludeSearch | 布尔值 | |
filter | 对象 | |
limit | 整型 | |
output | 查询 | |
preservekeys | 布尔值 | |
search | 对象 | |
searchByAny | 对象 | |
searchWildcardsEnabled | 布尔值 | |
sortorder | 字符串/数组 | |
startSearch | 布尔值 |
返回值
(integer/array)
返回以下:
- 一组对象;
- 如果
countOutput
参数被使用,返回对象的数量。
示例
从LLD规则中获取主机原型
从LLD规则中获取所有主机原型,组链接,组原型和标签
请求:
{
"jsonrpc": "2.0",
"method": "hostprototype.get",
"params": {
"output": "extend",
"selectInterfaces": "extend",
"selectGroupLinks": "extend",
"selectGroupPrototypes": "extend",
"selectTags": "extend",
"discoveryids": "23554"
},
"auth": "038e1d7b1735c6a5436ee9eae095879e",
"id": 1
}
响应:
{
"jsonrpc": "2.0",
"result": [
{
"hostid": "10092",
"host": "{#HV.UUID}",
"name": "{#HV.UUID}",
"status": "0",
"templateid": "0",
"discover": "0",
"custom_interfaces": "1",
"inventory_mode": "-1",
"groupLinks": [
{
"group_prototypeid": "4",
"hostid": "10092",
"groupid": "7",
"templateid": "0"
}
],
"groupPrototypes": [
{
"group_prototypeid": "7",
"hostid": "10092",
"name": "{#CLUSTER.NAME}",
"templateid": "0"
}
],
"tags": [
{
"tag": "Datacenter",
"value": "{#DATACENTER.NAME}"
},
{
"tag": "Instance type",
"value": "{#INSTANCE_TYPE}"
}
],
"interfaces": [
{
"main": "1",
"type": "2",
"useip": "1",
"ip": "127.0.0.1",
"dns": "",
"port": "161",
"details": {
"version": "2",
"bulk": "1",
"community": "{$SNMP_COMMUNITY}"
}
}
]
}
],
"id": 1
}
参考
来源
CHostPrototype::get() in ui/include/classes/api/services/CHostPrototype.php。