从零开始的Linux运维屌丝之路,资源免费分享平台   运维人员首选:简单、易用、高效、安全、稳定、社区活跃的开源软件

Zabbix通过API获取监控历史数据

发布:蔺要红08-20分类: 运维

工作中用到的脚本
#!/bin/bash
zabbix_url=http://xxxxxxxxx:50000/zabbix/api_jsonrpc.php

itemid=25577
token=$(curl -s -XPOST -H 'Content-Type: application/json-rpc' -d '
{
    "jsonrpc": "2.0",
    "method": "user.login",
    "params": {
        "user": "Admin",
        "password": "zabbix"
    },
    "id": 1,
    "auth": null
}'  $zabbix_url | jq ".result" | sed -e 's/"//g' )

#time_start=$(date +%s -d "2020-08-20 13:55")
#time_end=$(date +%s -d "2020-08-20 14:20")
time_end=$(date +%s)
let "time_start=time_end-60"

value=$(curl -s -XPOST -H 'Content-Type: application/json-rpc' -d "
{
    \"jsonrpc\": \"2.0\",
    \"method\": \"history.get\",
    \"params\": {
        \"itemids\": [\"$itemid\"] ,
        \"time_from\"	:$time_start ,
        \"time_till\"	:$time_end,
        \"limit\": 100
    },
    \"auth\": \"$token\",
    \"id\":1
}"  $zabbix_url | jq ".result[0].value"  |sed -e 's/"//g' -e "s/.*/print \"%.2f\"% (&\/1024.0\/1024.0)/" |python  )

echo "incoming4" $value

# outcoming4
itemid=25625

value=$(curl -s -XPOST -H 'Content-Type: application/json-rpc' -d "
{
    \"jsonrpc\": \"2.0\",
    \"method\": \"history.get\",
    \"params\": {
        \"itemids\": [\"$itemid\"] ,
        \"time_from\"	:$time_start ,
        \"time_till\"	:$time_end,
        \"limit\": 100
    },
    \"auth\": \"$token\",
    \"id\":1
}"  $zabbix_url | jq ".result[0].value"  |sed -e 's/"//g' -e "s/.*/print \"%.2f\"% (&\/1024.0\/1024.0)/" |python  )

echo "outcoming4" $value


 
Zabbix API可以通过JSON RPC协议来获取历史数据。
  可以采用脚本或者任何支持JSON RPC的工具来使用API。
  基本请求格式
  Zabbix API 简化的JSON请求如下:
  {
  "jsonrpc": "2.0",
  "method": "method.name",
  "params": {
  "param_1_name": "param_1_value",
  "param_2_name": "param_2_value"
  },
  "id": 1,
  "auth": "a826fca79a0795ccc1224dc76329972f",
  }
  下面一行一行来看:
  ● "jsonrpc": "2.0"-这是标准的JSON RPC参数以标示协议版本。所有的请求都会保持不变。
  ● "method": "method.name"-这个参数定义了真实执行的操作。例如:host.create、item.update,history.get等等
  ● "params"-这里通过传递JSON对象来作为特定方法的参数。如果你希望创建监控项,"name"和"key_"参数是需要的,每个方法需要的参数在Zabbix API文档中都有描述。
  ● "id": 1-这个字段用于绑定JSON请求和响应。响应会跟请求有相同的"id"。在一次性发送多个请求时很有用,这些也不需要唯一或者连续
  ● "auth": "a826fca79a0795ccc1224dc76329972f"-这是一个认证令牌【authentication token】用以鉴别用户、访问API。这也是使用API进行相关操作的前提-获取认证ID。(以上为转载http://paperplane.ruhoh.com/zabbix/intro-to-zabbix-api/)
  

  实例:获取192.168.211.60从2014.2.19 14:00:00到2014.2.19 14:10:00的cpu idle值
  基于curl命令:
  (1):认证并且取得加密字段
  curl -i -X POST -H 'Content-Type: application/json' -d '{"jsonrpc":
  "2.0","method":"user.login","params":{"user":"xxxx","password":"xxxx"},"auth":
  null,"id":0}' http://x.x.x.x/api_jsonrpc.php
  #之后会得到一串输出:{"jsonrpc":"2.0","result":"a826fca79a0795ccc1224dc76329972f","id":0}。记住这
  段输出。
  (2)获取监控主机的hostids
  curl -i -X POST -H 'Content-Type: application/json' -d '{"jsonrpc": "2.0","method":"host.get","params":{"output":["hostid"],"filter": {"host":"192.168.211.60"}},"auth": "a826fca79a0795ccc1224dc76329972f","id": 0}' http://x.x.x.x/api_jsonrpc.php
  #"hostid":"10243"
  (3)获得监控项itemids
  curl -i -X POST -H 'Content-Type: application/json' -d '{"jsonrpc": "2.0","method":"item.get","params":{"output":"itemids","hostids":"10243","search":{"key_":"system.cpu.util
  [,idle,avg1]"}},"auth": "a826fca79a0795ccc1224dc76329972f","id": 0}' http://x.x.x.x/api_jsonrpc.php
  #“item”:"24526"
  (4)获取监控项"system.cpu.util[,idle,avg1]"在2014.2.19 14:00~14:20的值
  curl -i -X POST -H 'Content-Type: application/json' -d '{"jsonrpc": "2.0","method":"history.get","params":{"history":0,"itemids":["24526"],"time_from":"1392789600","time_till":"1392790200","output":"extend"},"auth": "a826fca79a0795ccc1224dc76329972f","id": 0}' http://x.x.x.x/api_jsonrpc.php
  #输出:
  [{"itemid":"24526","clock":"1392789646","value":"95.7539","ns":"138978589"},
  {"itemid":"24526","clock":"1392789706","value":"84.9595","ns":"578198422"},
  {"itemid":"24526","clock":"1392789766","value":"94.5259","ns":"186216653"},
  {"itemid":"24526","clock":"1392789826","value":"96.2286","ns":"789434167"},
  {"itemid":"24526","clock":"1392789886","value":"94.7712","ns":"191954191"},
  {"itemid":"24526","clock":"1392789946","value":"90.8338","ns":"781241168"},
  {"itemid":"24526","clock":"1392790006","value":"89.1735","ns":"294674458"},
  {"itemid":"24526","clock":"1392790066","value":"92.3015","ns":"877714419"},
  {"itemid":"24526","clock":"1392790126","value":"96.3051","ns":"426421789"},
  {"itemid":"24526","clock":"1392790186","value":"97.7931","ns":"174500891"}]
  #“value”就是cpu idle值,采样间隔时间与监控项的数据更新时间一致。
  补充:获取192.168.211.60监控项"system.cpu.util[,idle,avg1]"在2014年2月19日 下午2:02:46 的值
  curl -i -X POST -H 'Content-Type: application/json' -d '{"jsonrpc": "2.0","method":"history.get","params":{"history":0,"itemids":["24526"],"time_from":"1392789600","time_till":"1392790200","output":"extend","filter":{"clock":"1392789766"}},"auth": "a826fca79a0795ccc1224dc76329972f","id": 0}' http://x.x.x.x/api_jsonrpc.php
  #"value":"94.5259"要获取的值
  

参考:
  Zabbix API 官方文档:https://www.zabbix.com/documentation/2.2/manual/api
  
 
温馨提示如有转载或引用以上内容之必要,敬请将本文链接作为出处标注,如有侵权我会在24小时之内删除!

欢迎使用手机扫描访问本站