,作者wanger

运维开发故事

用于输出干货的公众号,包括学习过程中的笔记以及遇到的坑,包括但不限于Linux运维,devops工具链,k8s容器化技术,监控,日志收集,网络安全,Python或GO开发,本号作者有wanger、Double冬、素心、刘大仙、华仔、乔克等

感谢社区专家Wanger供稿!

Wanger | Zabbix开源社区签约专家

Zabbix运维工程师,熟悉Zabbix开源监控系统的架构。乐于分享Zabbix运维经验,个人公众号“运维开发故事”。

擅长领域:Zabbix基础设施运维以及Zabbix图形化展示。

01 - Zabbix Agent2监控docker的实现原理

首先我们来看一下zabbix agent2监控docker插件的实现原理,其实就是通过调用docker的API来获取数据,插件目录位于zabbix-agent2/src/go/plugins/docker,我们先来看一下client.go文件 这里就是定义了使用UNIX套接字地址来进行docker客户端与服务端的通信。




zabbix 完整配置 docker compose zabbix agent docker_API


config.go定义了docker插件的默认配置,默认套接字位置为/var/run/docker.sock,定义默认超时时间为全局代理超时时间,通过调用conf.Unmarshal()函数,将配置文件中的插件参数加载到Options结构体中。


zabbix 完整配置 docker compose zabbix agent docker_运维_02


这个是检查配置文件输入的Endpoint是否有错误。


zabbix 完整配置 docker compose zabbix agent docker_API_03


再来看一下docker.go,这里定义了docker的监控项的键值,以及对应的API请求路径,参数长度。


zabbix 完整配置 docker compose zabbix agent docker_运维_04


这里是实现了一个Query方法来对根据传来的API路径构造GET请求获取数据。


zabbix 完整配置 docker compose zabbix agent docker_docker export_05


也就相当于这种请求,其中1.28是一个常量,表示docker的API版本,/var/run/docker.sock是默认套接字位置。


zabbix 完整配置 docker compose zabbix agent docker_运维_06


这里实现了一个Export接口,将对应的key传入给Query方法,返回一个json格式的数据,模板上会创建一些依赖项,使用预处理进程对json数据进行分割。


zabbix 完整配置 docker compose zabbix agent docker_docker_07


下面是zabbix实现自动发现容器和镜像的两个方法,会返回包含容器和镜像信息的json数据。


zabbix 完整配置 docker compose zabbix agent docker_docker export_08


对这些指标进行初始化,第一个参数为指向插件实现的指针,第二个参数为插件名称,第三个参数指标1的键值,第二个参数为指标1的说明,往后以此类推。


zabbix 完整配置 docker compose zabbix agent docker_API_09


了解了docker插件的实现思路后我们可以根据我们的需求进行扩展,添加对应的api获取数据就可以了,或者根据这个思路在zabbix agent上实现相同的自定义脚本,甚至可以根据docker插件的实现逻辑来自己编写插件实现其他的监控需求。

02-使用Zabbix Agent2的模板监控docker

链接docker模板:


zabbix 完整配置 docker compose zabbix agent docker_docker_10


然后就可以看到docker的状态了。


zabbix 完整配置 docker compose zabbix agent docker_API_11


zabbix 完整配置 docker compose zabbix agent docker_docker_12