zabbix agent是在客户端上需要的一个组件,在这种被动模式下,zabbix server的压力就会大大减轻,因为是在agent端开始推送信息给服务端,而不是服务端主动去获取。
简单来上个图,其实这个架构和原理想必大家非常熟悉了。
客户单的server和zabbix server之间通过网络的特定端口来进行交互。所以在两个server间需要考虑防火墙。
现在如果要在每个server安装这个agent,至少我们需要把安装介质拷贝过去,创建相应的目录,创建对应的用户,然后配置网络,最后运行agent的安装文件做make install等等。
如果每个客户端都这么做一遍,其实步骤都是类似,花费时间不少,还是非常耗费精力的。我就自己试着手工方式安装,结果安装了几台之后,备受煎熬。中间某些步骤有操作失误,又得分析分析,最后发现是个很简单的小错误。
至少对于我来说,我认为最简单的安装方式就是只提供一个ip地址,然后剩下的事情都能自动完成。
比如假设我们有个脚本 zabbix_agent.sh 只需要输入需要安装agent的机器ip地址,就会开始自动安装,这样就省时省力了。
我们可以把问题继续细化,把它细化称为可以实现的几个部分。比如我在一台中间代理服务器上,需要通过这台服务器连接到各个server安装agent,那么首先要做的就是在目标机器上创建对应的目录,把安装所需要的文件等都给拷贝过去,可以简称发布agent
然后文件目录等都具备之后,我们就需要配置网络防火墙,创建zabbix agent的操作系统用户,调用安装文件,这个部分简称为部署agent
所以我把脚本分成两个部分,运行的时候只需要提供ip地址即可。
./publish_zabbix_agd.sh $1
./zabbix_agent_dep.sh $1
明确了目标任务之后,剩下的就是具体的实现了。
对于发布程序来说,为了达到一键式发布,部署的效果,使用expect的方式来动态运行脚本。
目前我采用的方式如下:
发布agent的脚本内容如下,假设agent的目录为new_agent,就线创建文件夹,然后把安装文件拷贝到指定的目录下/home/zabbix