横空大气排山去,砥柱人间是此峰web
牛兆濂《登华岳南峰极顶七绝》
Zabbix Agent2监控docker容器
首先咱们先来看一下zabbix agent2监控docker插件的实现原理,其实就是经过调用docker的API来获取数据,插件目录位于zabbix-agent2/src/go/plugins/docker,咱们先来看一下client.go文件 这里就是定义了使用UNIX套接字地址来进行docker客户端与服务端的通讯config.go定义了docker插件的默认配置,默认套接字位置为/var/run/docker.sock,定义默认超时时间为全局代理超时时间,经过调用conf.Unmarshal()函数,将配置文件中的插件参数加载到Options结构体中
这个是检查配置文件输入的Endpoint是否有错误
再来看一下docker.go,这里定义了docker的监控项的键值,以及对应的API请求路径,参数长度
这里是实现了一个Query方法来对根据传来的API路径构造GET请求获取数据
也就至关于这种请求,其中1.28是一个常量,表示docker的API版本,/var/run/docker.sock是默认套接字位置
这里实现了一个Export接口,将对应的key传入给Query方法,返回一个json格式的数据,模板上会建立一些依赖项,使用预处理进程对json数据进行分割
下面是zabbix实现自动发现容器和镜像的两个方法,会返回包含容器和镜像信息的json数据
对这些指标进行初始化,第一个参数为指向插件实现的指针,第二个参数为插件名称,第三个参数指标1的键值,第二个参数为指标1的说明,日后以此类推docker
了解了docker插件的实现思路后咱们能够根据咱们的需求进行扩展,添加对应的api获取数据就能够了,或者根据这个思路在zabbix agent上实现相同的自定义脚本,甚至能够根据docker插件的实现逻辑来本身编写插件实现其余的监控需求json
下面咱们来使用agent2的模板监控docker
连接docker模板而后就能够看到docker的状态了api


欢迎各位一块儿交流微信
本文分享自微信公众号 - 运维开发故事(mygsdcsf)。
若有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一块儿分享。运维