使用shell脚本一键安装zabbix并配置客户端的自动发现选项

简介:

  1.缘由:

    我自己的ESXi服务器上上最近新加了好多虚拟主机,但我现在还不会安装,使用,那种批量运维工具(saltstack,ansible,puppet等)。虽然还有一种方法:就是通过shell工具一次打开若干个窗口,然后在编辑框中输一行行的输入命令,点击全部窗口执行。可是我的老笔记本已经撑不住这么开这么多窗口了,。

    2.然后

    开始写zabbix_agent安装脚本,通过手工上传到各个虚拟机中执行,这里推荐大家在初始化Linux的时候,别忘记安装lrzsz,rz和sz可以拖动上传文件到Linux中。很方便。

    还有一种思路:初始化Linux时,在管理机上配置一个共享挂载文件目录到那些被管理机上,然后通过这种方式进行分发脚本。但觉得路子有点歪。还不如去整个ansible来做。这个留作后话吧。

    

     

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
printf  "关闭并屏蔽服务firewalld."
systemctl stop firewalld >  /dev/null  2>&1
systemctl mask firewalld >  /dev/null  2>&1
printf  "\033[32;1m%20s\033[0m\n"  "[ OK ]"
printf  "安装zabbix3.4.2源......."
yum -y  install  http: //repo .zabbix.com /zabbix/3 .4 /rhel/7/x86_64/zabbix-release-3 .4-2.el7.noarch.rpm >  /dev/null  2>&1
printf  "\033[32;1m%20s\033[0m\n"  "[ OK ]"
printf  "安装zabbix-agent........"
yum -y  install  zabbix-agent >  /dev/null  2>&1
printf  "\033[32;1m%20s\033[0m\n"  "[ OK ]"
printf  "更改zabbix-agent配置文件"
sed   -i  "s/Server=127.0.0.1/Server=192.168.1.120/g"  /etc/zabbix/zabbix_agentd .conf
sed   -i  "s/ServerActive=127.0.0.1/ServerActive=192.168.1.120/g"  /etc/zabbix/zabbix_agentd .conf
sed   -i  "s/# HostMetadataItem=/HostMetadataItem=system.uname/g"  /etc/zabbix/zabbix_agentd .conf
sed   -i  "s/# HostnameItem=system.hostname/HostnameItem=system.hostname/g"  /etc/zabbix/zabbix_agentd .conf
sed   -i  "s/Hostname=Zabbix server/# Hostname=Zabbix server/g"  /etc/zabbix/zabbix_agentd .conf
printf  "\033[32;1m%20s\033[0m\n"  "[ OK ]"
printf  "设置zabbix-agent自启动.."
systemctl  enable  zabbix-agent >  /dev/null  2>&1
printf  "\033[32;1m%20s\033[0m\n"  "[ OK ]"
printf  "启动zabbix-agent服务...."
systemctl restart zabbix-agent >  /dev/null  2>&1
printf  "\033[32;1m%20s\033[0m\n"  "[ OK ]"

 wKiom1m7aKuQGKh1AABKjb6MEK8325.jpg-wh_50

讲解下:

  •  禁止防火墙自启动本来可以用systemctl disable firewalld 这个命令在CentOS 7上没毛病,

     但是在同源的FedoraServer26上总是无法成功,所以使用更加粗暴的systemctl mask firewalld的  方式,直接将firewalld的目录指偏,让systemctl找不到firewalld。

  • zabbix使用了最新的版本

  • 更改配置文件这里,我对服务器地址进行了重新指定。

        即Server=192.168.1.120(被动,适用于自动发现动作)

         ServerActive=192.168.1.120 (主动,适用于自己向服务器发起注册操作)

         HostnameItem=system.hostname(定义主机的名称,在自动注册的时候有用)

         HostMetadataItem=system.uname(定义主机的元数据信息,在自动注册的时候有用)

  • 然后就是开启服务啦。

       

     

    

 本文转自 angry_frog 51CTO博客,原文链接:http://blog.51cto.com/l0vesql/1965543


相关文章
|
15天前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
53 1
|
1天前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
11 2
6种方法打造出色的Shell脚本
|
6天前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
31 6
|
2天前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
1月前
|
监控 Unix Shell
shell脚本编程学习
【10月更文挑战第1天】shell脚本编程
58 12
|
30天前
|
存储 运维 监控
自动化运维:使用Shell脚本简化日常任务
【9月更文挑战第35天】在IT运维的日常工作中,重复性的任务往往消耗大量的时间。本文将介绍如何通过编写简单的Shell脚本来自动化这些日常任务,从而提升效率。我们将一起探索Shell脚本的基础语法,并通过实际案例展示如何应用这些知识来创建有用的自动化工具。无论你是新手还是有一定经验的运维人员,这篇文章都会为你提供新的视角和技巧,让你的工作更加轻松。
32 2
|
24天前
|
存储 Shell Linux
【Linux】shell基础,shell脚本
Shell脚本是Linux系统管理和自动化任务的重要工具,掌握其基础及进阶用法能显著提升工作效率。从简单的命令序列到复杂的逻辑控制和功能封装,Shell脚本展现了强大的灵活性和实用性。不断实践和探索,将使您更加熟练地运用Shell脚本解决各种实际问题
17 0
|
2月前
|
Shell
shell脚本变量 $name ${name}啥区别
shell脚本变量 $name ${name}啥区别
|
2月前
|
人工智能 监控 Shell
常用的 55 个 Linux Shell 脚本(包括基础案例、文件操作、实用工具、图形化、sed、gawk)
这篇文章提供了55个常用的Linux Shell脚本实例,涵盖基础案例、文件操作、实用工具、图形化界面及sed、gawk的使用。
169 2
|
2月前
|
Shell
Shell脚本有哪些基本语法?
【9月更文挑战第4天】
58 18

推荐镜像

更多