Curl读取Zabbix API的TrubleShooting

一般curl可以通过POST直接读取zabbix API接口来执行脚本,进行批量配置和获取相关信息

 curl -i -X POST -H 'Content-Type:application/json' -d '{"jsonrpc":"2.0","method":"user.login","params":{"user":"admin","password":"xxxx"},"auth":null,"id":0}' http://10.40.x.x/zabbix/api_jsonrpc.php
HTTP/1.1 200 OK
Date: Fri, 09 Aug 2019 08:17:05 GMT
Server: Apache/2.4.29 (Ubuntu)
Access-Control-Allow-Origin: *
Access-Control-Allow-Headers: Content-Type
Access-Control-Allow-Methods: POST
Access-Control-Max-Age: 1000
Content-Length: 68
Content-Type: application/json

{"jsonrpc":"2.0","result":"b0535ba016be1f2a380ebf3096bca711","id":0}

当我们通过curl读取API发生失败时,需要了解其原因,便于排查问题,这时可以增加参数"-v",这样在执行读取时就会输出具体的过程,如下是读取成功,显示HTTP/1.1 200 OK,并得了 “result”:"07eb9198785e8f4c09028ddae6b41f2b

curl -i -v -X POST -H ‘Content-Type:application/json’ -d ‘{“jsonrpc”:“2.0”,“method”:“user.login”,“params”:{“user”:“admin”,“password”:“xxxx”},“auth”:null,“id”:0}’ http://10.40.x.x/zabbix/api_jsonrpc.php

Note: Unnecessary use of -X or --request, POST is already inferred.
*   Trying 10.40.x.x...
* TCP_NODELAY set
* Connected to 10.40.x.x (10.40.x.x) port 80 (#0)
> POST /zabbix/api_jsonrpc.php HTTP/1.1
> Host: 10.40.x.x
> User-Agent: curl/7.58.0
> Accept: */*
> Content-Type:application/json
> Content-Length: 107
> 
* upload completely sent off: 107 out of 107 bytes
< HTTP/1.1 200 OK
HTTP/1.1 200 OK
< Date: Fri, 09 Aug 2019 06:47:26 GMT
Date: Fri, 09 Aug 2019 06:47:26 GMT
< Server: Apache/2.4.29 (Ubuntu)
Server: Apache/2.4.29 (Ubuntu)
< Access-Control-Allow-Origin: *
Access-Control-Allow-Origin: *
< Access-Control-Allow-Headers: Content-Type
Access-Control-Allow-Headers: Content-Type
< Access-Control-Allow-Methods: POST
Access-Control-Allow-Methods: POST
< Access-Control-Max-Age: 1000
Access-Control-Max-Age: 1000
< Content-Length: 68
Content-Length: 68
< Content-Type: application/json
Content-Type: application/json

< 
* Connection #0 to host 10.40.x.x left intact
{"jsonrpc":"2.0","result":"07eb9198785e8f4c09028ddae6b41f2b","id":0}

如下为读取失败时,会得到提示HTTP/1.1 404 Not Found,最后也未得到result,而是Closing connection 0


curl -i -v -X POST -H 'Content-Type:application/json' -d '{"jsonrpc":"2.0","method":"user.login","params":{"user":"admin","password":"xxxx"},"auth":null,"id":0}' http://10.41.x.x/zabbix/api_jsonrpc.php     
Note: Unnecessary use of -X or --request, POST is already inferred.
*   Trying 10.41.x.x...
* TCP_NODELAY set
* Connected to 10.41.x.x (10.41.x.x) port 80 (#0)
> POST /zabbix/api_jsonrpc.php HTTP/1.1
> Host: 10.40.x.x
> User-Agent: curl/7.58.0
> Accept: */*
> Content-Type:application/json
> Content-Length: 107
> 
* upload completely sent off: 107 out of 107 bytes
< HTTP/1.1 404 Not Found
HTTP/1.1 404 Not Found
< Date: Fri, 09 Aug 2019 06:50:58 GMT
Date: Fri, 09 Aug 2019 06:50:58 GMT
< Server: Apache/2.2.15 (CentOS)
Server: Apache/2.2.15 (CentOS)
< Content-Length: 298
Content-Length: 298
< Connection: close
Connection: close
< Content-Type: text/html; charset=iso-8859-1
Content-Type: text/html; charset=iso-8859-1

< 
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html><head>
<title>404 Not Found</title>
</head><body>
<h1>Not Found</h1>
<p>The requested URL /zabbix/api_jsonrpc.php was not found on this server.</p>
<hr>
<address>Apache/2.2.15 (CentOS) Server at 10.41.x.x Port 80</address>
</body></html>
* Closing connection 0

### Zabbix API 官方文档与使用指南 Zabbix 提供了一个全面的官方文档,涵盖了 API 的基本概念、方法以及具体实现细节。以下是关于如何访问和利用这些资源的信息: #### 访问 Zabbix API 官方文档 可以通过以下链接直接访问 Zabbix 官方 API 文档[^1]: [Zabbix API Documentation](https://www.zabbix.com/documentation/current/en/manual/api) 该页面包含了完整的 API 方法列表及其参数描述,适合开发者深入研究。 #### 如何高效阅读和应用官方文档? 为了充分利用 Zabbix API 文档中的信息,建议按照以下方式操作: - **熟悉基础结构**:了解 JSON-RPC 协议的基础知识,因为 Zabbix API 基于此协议工作。 - **探索核心功能**:从 `apiinfo` 开始尝试简单的方法,比如获取服务器版本号[^4]: ```bash curl http://<zabbix_server>/zabbix/api_jsonrpc.php \ -H 'Content-Type:application/json-rpc' \ -d '{"jsonrpc":"2.0","method":"apiinfo.version","params":[],"id":1}' ``` - **逐步扩展复杂度**:一旦掌握了基本调用模式,可以进一步学习其他模块的功能,例如主机管理 (`host`) 或触发器管理 (`trigger`)。 #### Java 环境下的集成支持 如果计划在基于 JVM 的环境中部署解决方案,则可能需要用到第三方库简化交互过程。例如,在 Maven 项目中添加如下依赖即可引入封装好的客户端类[^3]: ```xml <dependency> <groupId>io.github.hengyunabc</groupId> <artifactId>zabbix-api</artifactId> <version>最新稳定版</version> </dependency> ``` 注意替换 `<latest_stable_version>` 为实际可用版本号前缀匹配项 (如 `0.x.y`) 并确认其兼容性满足当前需求场景下所使用的 Zabbix 版本要求。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值