Ansible批量部署zabbix-agent(含zabbix-agent的yum源,zabbix自动发现和添加的界面操作)

简介: Ansible批量部署zabbix-agent(含zabbix-agent的yum源,zabbix自动发现和添加的界面操作)

1 在zabbix-server机器上安装ansible

yum -y install ansible

2 将准备安装zabbix-agent的服务器写入ansible主机清单

vim /etc/ansible/hosts

[zabbix]
192.168.123.131  hostname=node1
192.168.123.137  hostname=node2
192.168.123.138  hostname=node3

注:其中hostname 是后面template模块会用到的hostname变量

3 创建部署所需要的role—zabbix-agent

cd /etc/ansible/roles
mkdir -pv zabbix-agent/{files,templates,tasks}

注: 其中zabbix-agent下的三个文件夹都很重要,files下可以放zabbix-agent安装包或者yum源,templates放含有变量hostname的zabbix-agent配置文件

3.1 在files目录下,配置yum源(这个yum源直接用来配置zabbix-server也完全没问题的)

cd /etc/ansible/roles/zabbix-agent/files

[root@zabbix-server files]# vim zabbix.repo

[zabbix]
name=zabbix
baseurl=https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/
gpgcheck=0
enabled=1
[zabbix2]
name=zabbix frontend
baseurl=https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/frontend/
gpgcheck=0
enabled=1

3.2 在templates目录下,cp配置文件,设置变量。

server和server active都设置为zabbix-server的ip,hostname使用变量。cp的配置文件一定是j2结尾

cp /etc/zabbix/zabbix_agentd.conf  /etc/ansible/roles/zabbix-agent/templates/zabbix_agentd.conf.j2

3e6851307ab54590b9ec5159878e3825.png

注:配置文件中,上面三个位置需要修改

3.3 在tasks目录下,创建main.yml 文件

vim /etc/ansible/roles/zabbix-agent/tasks/main.yml

- name: get the zabbix-agent
  copy:
    src: zabbix.repo
    dest: /etc/yum.repos.d/
- name: install the zabbix-agent
  yum:
    name: zabbix-agent
    state: present
- name: copy the zabbix_agentd.conf
  template:
    src: zabbix_agentd.conf.j2
    dest: /etc/zabbix/zabbix_agentd.conf
- name: start zabbix-agent
  service:
    name: zabbix-agent
    state: started
    enabled: true

注: zabbix-agent目录下可以直接调用,所以无需写明templates和files的绝对路径

4 给其他节点服务器做免密

ssh-keygen

然后按三次回车键,会显示密钥 创建成功,如下所示

Generating public/private rsa key pair.

Enter file in which to save the key (/root/.ssh/id_rsa):

Enter passphrase (empty for no passphrase):

Enter same passphrase again:

Your identification has been saved in /root/.ssh/id_rsa.

Your public key has been saved in /root/.ssh/id_rsa.pub.

The key fingerprint is:

SHA256:SUHLRNME2qo3Z2ly2UUA6xL/sWSMffpKSqvdPHneaJI root@node1

The key’s randomart image is:

±–[RSA 2048]----+

| oO=o |

| = =… |

| o * . |

| * = . |

| o S * o |

| . . B * |

| . + O *o |

| . X *E.oo |

| …+ +B+ . |

±—[SHA256]-----+

ssh-copy-id root@192.168.123.131
ssh-copy-id root@192.168.123.137
ssh-copy-id root@192.168.123.138

以上三台密钥设置成功

5 配置一个playbook,我直接在root下创建的

vim zabbix-agent.yml
---
- name: zabbix_install
  hosts: zabbix
  roles:
  - zabbix-agent

6 执行剧本,ansible部署zabbix-agent完成

ansible-playbook zabbix-agent.yml

执行完成

PLAY [zabbix_install]

TASK [Gathering Facts]

******************************************************************************* ok: [192.168.123.138] ok: [192.168.123.137] ok: [192.168.123.131]


TASK [get the zabbix-agent]

************************************************************************** ok: [192.168.123.137] ok: [192.168.123.138] ok: [192.168.123.131]


TASK [install the zabbix-agent]

********************************************************************** ok: [192.168.123.138] ok: [192.168.123.131] ok: [192.168.123.137]


TASK [zabbix-agent : copy the zabbix_agentd.conf]

**************************************************** ok: [192.168.123.137] ok: [192.168.123.138] ok: [192.168.123.131]


TASK [start zabbix-agent]

**************************************************************************** changed: [192.168.123.137] changed: [192.168.123.138] changed:

[192.168.123.131]


PLAY RECAP


192.168.123.131 : ok=5 changed=1 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

192.168.123.137 : ok=5 changed=1 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

192.168.123.138 : ok=5 changed=1 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0

7 zabbix-server界面设置自动发现主机,并且添加至主机组(附大量图片)

创建发现规则

96a12e7ce0304c57b044e010b7903fd6.png

7e6bafcecf5046eda01ed5acd255d6af.png最后点击add,我这个创建好了,所以是update按钮

创建动作

6dc0e681a59e494bbded20b73be2ddd4.png

57da283d580c4d77a2de9c8c7467cd50.png

注: 还需要点击operations 点击操作哦,动作和操作同时完成才ok

0e3717a75b7d413fa8cabf5e63299467.png

以上完成了,点击add,或者update即可

8 zabbix-server中查看已发现,和成功添加的主机

e8ba06b3d8c940409adfc892f734fb03.png

怎么看自己添加的主机呢?最后一张图了,坚持就是胜利

3ce5961ae0ef419a8b46ee27f10cc661.png

完结,撒花~~~~

目录
相关文章
|
4月前
|
缓存 Linux Shell
RHEL7部署http应用配置共享yum源
RHEL7部署http应用配置共享yum源
96 0
|
9月前
|
存储 数据采集 缓存
【运维知识进阶篇】Zabbix5.0稳定版详解9(Zabbix优化:高并发对MySQL进行拆分、Zabbix-agent主动上报模式、使用proxy代理模式、系统自带监控项优化、进程优化、缓存优化)
【运维知识进阶篇】Zabbix5.0稳定版详解9(Zabbix优化:高并发对MySQL进行拆分、Zabbix-agent主动上报模式、使用proxy代理模式、系统自带监控项优化、进程优化、缓存优化)
243 0
|
9月前
|
运维 负载均衡 关系型数据库
【运维知识进阶篇】用Ansible Roles重构LNMP架构(Linux+Nginx+Mariadb+PHP),实现4个项目一键部署
【运维知识进阶篇】用Ansible Roles重构LNMP架构(Linux+Nginx+Mariadb+PHP),实现4个项目一键部署
113 0
|
10月前
|
运维 监控
【运维】在zabbix-server的web界面配置agent主机监控
【运维】在zabbix-server的web界面配置agent主机监控
|
5月前
|
Java Linux Docker
Linux【上手 01】MobaXterm+系统版本查看+hostname修改+hosts修改+yum源配置+jdk安装+docker部署使用(不断完善)
Linux【上手 01】MobaXterm+系统版本查看+hostname修改+hosts修改+yum源配置+jdk安装+docker部署使用(不断完善)
69 0
|
10月前
管理工具ansible的部署
管理工具ansible的部署
67 0
管理工具ansible的部署
|
6月前
|
Linux 网络安全 调度
使用docker部署awx-1.7.1.0(ansible图形化界面)
使用docker部署awx-1.7.1.0(ansible图形化界面)
469 0
|
6月前
|
弹性计算 关系型数据库 数据库
通过计算巢轻松部署 Ansible Semaphore
AnsibleSemaphore是一个现代化的Ansible用户界面,通过计算巢可轻松部署。
158 1
通过计算巢轻松部署 Ansible Semaphore
|
7月前
|
监控 关系型数据库 MySQL
Zabbix分布式监控实战(二)——CentOS 7.5安装Zabbix-agent 5.0监控Mysql数据库
Zabbix分布式监控实战(二)——CentOS 7.5安装Zabbix-agent 5.0监控Mysql数据库
|
8月前
|
缓存 安全 网络协议
部署YUM仓库及NFS共享服务
部署YUM仓库及NFS共享服务
166 0

推荐镜像

更多