当我们的Zabbix自动注册+Ansible自动部署在一起时,会碰出什么样的火花,答案就是可以实现执行ansible的一条命令,监控任意一台或多台主机。
目录
一、配置好自动注册规则
二、编写Ansible playbook
三、运行Ansible,查看监控效果
一、配置好自动注册规则
二、编写Ansible playbook
1、编写playbook
[root@Ansible zabbix]# cat zabbix.yaml
- hosts: web03vars:- SERVER_IP: 172.16.1.71tasks:- name: Install Zabbix-Agentyum:name: https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-agent-5.0.34-1.el7.x86_64.rpmstate: present- name: Install centos-release-scl and Agentyum:name: centos-release-sclstate: present- name: Install Agentyum:name: zabbix-agentstate: present- name: Config Zabbix-Agenttemplate:src: zabbix_agentd.conf.j2dest: /etc/zabbix/zabbix_agentd.confnotify: Restart Zabbix Agent- name: Scp Zabbix Agent Configurecopy:src: ./zabbix_agentd.ddest: /etc/zabbix/- name: Start Zabbix Agentsystemd:name: zabbix-agentstate: startedenabled: yeshandlers:- name: Restart Zabbix Agentsystemd:name: zabbix-agentstate: restarted
2、编写主机清单
[root@Ansible zabbix]# cat hosts
[web_group]
web03 ansible_ssh_host=172.16.1.9
3、编写zabbix客户端配置文件,方便进行推送
[root@Ansible zabbix]# grep -v '^$\|^#' zabbix_agentd.conf.j2
PidFile=/var/run/zabbix/zabbix_agentd.pid
LogFile=/var/log/zabbix/zabbix_agentd.log
LogFileSize=0
Server={{ SERVER_IP }}
ServerActive={{ SERVER_IP }}
Hostname={{ ansible_hostname }}
Include=/etc/zabbix/zabbix_agentd.d/*.conf
4、如果需要自定义监控项也可以放到zabbix_agentd.d目录,跟配置文件一起推送过去,最终目录结构如下
[root@Ansible zabbix]# ll
total 24
-rw-r--r-- 1 root root 46 Jul 2 17:37 hosts
-rw-r--r-- 1 root root 16012 Jul 8 11:51 zabbix_agentd.conf.j2
drwxr-xr-x 2 root root 6 Jul 2 17:13 zabbix_agentd.d
-rw-r--r-- 1 root root 947 Jul 8 11:45 zabbix.yaml
三、运行Ansible,查看监控效果
如果主机多的话就用脚本做免密钥
[root@Ansible ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub root@10.0.0.9[root@Ansible zabbix]# ansible-playbook -i hosts zabbix.yaml
执行后发现动作日志以及执行了自动注册的动作
也触发了邮箱
主机列表成功添加了主机
也会自动关联我们设定的模板,数据也可以采集到,大功告成!
我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!