想要达到的效果:一条命令,快速对多台主机部署zabbix_agent

实现思路:从源码编译编译出zabbix_agentd,准备好安装脚本,将安装脚本和编译出的agent一起上传到FTP服务器,在ansible机器上面执行下载脚本并且执行。agent安装完成检查一下端口是否起来(主动模式就检查一下进程有没有拉起来)

提示:选择主动模式启动agent的时候,也需要有对应的模版

最后的效果:

1、在ansible机器上面一条命令实现对客户端的安装

2、脚本实现修改配置文件,不同主机不同的Hostname

3、添加了zabbix_agentd服务,并且将zabbix_agentd设置为开机自启

4、对于active模式,配置了自动注册的参数

环境准备:

1)       系统版本:Linux Red Hat 6.5

2)       server和agent最好YUM源搭建OK

3)       FTP服务器IP:172.16.255.22     路径: /var/ftp

4)       Zabbix源码包

5)       客户端默认防火墙关闭(/etc/init.d/itpables stop)

如果防火墙开启,参考命令:

主被是相对agent而言

被动模式:服务器打开10051端口,客户端10050端口;(端口由配置文件决定,这里不做更改)

主动模式:服务器打开10051端口(纯主动模式)。

主被混合模式:server打开10051端口,agent打开10050端口

vim /etc/sysconfig/iptables    #增加一行

-A INPUT -m state --state NEW -m tcp -p tcp --dport  -j ACCEPT    #agent    
-A INPUT -m state --state NEW -m tcp -p tcp --dport 10051 -j ACCEPT    #server
####最后修改完配置文件,别忘记reload一下,或者重启防火墙生效

6)       客户端默认selinux设置为禁用

没禁用,参考命令:

sed –I ‘s/SELINUX=enforcing/SELINUX=disabled/g’ /etc/sysconfig/selinux
setenforce #设置disabled,马上生效
getenforce #检查

IP地址准备,批量建立信任关系

#如果某一台主机存在多个IP地址,就是用下面的命令,对主机获取单个IP

扫描网段脚本地址

#在这之前,已经对19端扫描过了,得到host_19的这个文件
ansible -i /opt/shell/lizuofang/beleve//hosts_19 dev -m shell -a "source /etc/profile ;ip addr|egrep 'eth.$' | tr '/' ' '|grep -v 'secondary' "|grep 'inet' |awk '{print $2}' |sort -n -t. -k4 |uniq > /tmp/zabbix19 cat /tmp/zabbix19 |awk '{print $2}' |sort -n -t. -k4 |uniq|wc -l      #对IP进行排序,方便查看

———————————————————安装libselinux-python

#ansible拷贝文件的时候,必须安装这个,不然报错
ansible -i h19 h19 -m shell -a 'yum install libselinux-python -y' -K --become ansible -i t ht -m shell -a 'wget ftp://192.168.20.25/rhe65.repo;mv rhe65.repo /etc/yum.repos.d/' -K --become

Agentd客户端编译压缩上传

从源码编译zabbix_agentd

[root@zabbix zabbix] tar xvf zabbix-3.2..tar.gz

[root@zabbix zabbix] cd zabbix-3.2. #进入源码所在的目录

[root@zabbix zabbix-3.2.]# ./configure --prefix=/usr/local/zabbix_agent --enable-agent

[root@zabbix zabbix-3.2.]# make && make install

##这个时候会在/usr/local/目录下会生成一个zabbix_agentd的目录

修改zabbix_agentd服务脚本

#给脚本执行权限

[root@zabbix zabbix-3.2.]# chmod  misc/init.d/tru64/zabbix_agentd

#修改zabbix_agentd服务启动脚本,使zabbix_agentd服务支持开启自启

[root@zabbix zabbix-3.2.]# sed -i '/bin\/sh/a #\n# chkconfig: 35 90 10\n# description:  Starts and stops Zabbix Agent using chkconfig' misc/init.d/tru64/zabbix_agentd

[root@zabbix zabbix-3.2.]# sed -i 's/DAEMON=/usr/local/sbin/zabbix_agentd

/ DAEMON=/usr/local/zabbix_agent/sbin/zabbix_agentd

/g' misc/init.d/tru64/zabbix_agentd

将编译后生成的目录以服务启动脚本拷贝在一起,并且压缩

[root@zabbix zabbix-3.2.] mkdir  /opt/zabbix_agent

[root@zabbix zabbix-3.2.] cp misc/init.d/tru64/zabbix_agentd /opt/zabbix_agent

[root@zabbix zabbix-3.2.] cd /opt/zabbix_agent

[root@zabbix zabbix_agent] cp -rf  /usr/local/zabbix_agent .

[root@zabbix zabbix_agent] zip -r zabbix_agent.zip *

将压缩文件上传到FTP服务器

 [root@zabbix opt] scp zabbix_agent.zip watson@172.16.255.22:/tmp     

###登录到FTP服务器,将/tmp/路径下面的压缩包,转移到ftp服务器跟路径中,便于其他机器下载,路径为/var/ftp/zabbix/zabbix_agentd.zi

zabbix_agent安装脚步

在ftp服务器上,

路径为/var/ftp/zabbix

被动模式的安装脚本

vim /var/ftp/zabbix/install_agent_passive.sh

#!/bin/bash
# install_agent_passive.sh
PAHT="/usr/local/sbin:/usr/sbin:/sbin:/usr/lib64/qt-3.3/bin:/usr/local/bin:/bin:/usr/bin";
FTP_Server="172.16.255.22"
PKT_PATH="zabbix/zabbix_agent.zip"
source /etc/profile;
cd /tmp
wget ftp://$FTP_Server/$PKT_PATH
unzip zabbix_agent.zip
mv zabbix_agent/zabbix_agent /usr/local/
mv zabbix_agentd/zabbix_agentd /etc/init.d/
useradd zabbix
##增加zabbix用户到wheel数组
egrep wheel /etc/group > /dev/null
if [ $? -eq ]
then
usermod -G wheel zabbix
fi
egrep ficommon /etc/group > /dev/null
if [ $? -eq ]
then
usermod -G ficommon zabbix
fi
echo zabbix:zabbix@ |chpasswd
chmod /etc/init.d/zabbix_agentd
#cp /usr/local/zabbix_agent/sbin/zabbix_agentd /usr/local/sbin/
service zabbix_agentd start
#设置开机自启
sed -i ‘/bin\/sh/a\# chkconfig: ’ /etc/init.d/zabbix_agentd
chkconfig zabbix_agentd on
#echo "/etc/init.d/zabbix_agentd start" >> /etc/rc.local
rm -rf /tmp/zabbix_agent.zip

主动模式的安装脚本

vim /var/ftp/zabbix/install_agent_active.sh

#!/bin/bash
PAHT="/usr/local/sbin:/usr/sbin:/sbin:/usr/lib64/qt-3.3/bin:/usr/local/bin:/bin:/usr/bin";
FTP_Server="192.168.20.25"
PKT_PATH="zabbix/zabbix_agent.zip"
#自动注册参数
AOTU_Resgister="aotu_resgister32"
source /etc/profile;
cd /tmp
wget ftp://$FTP_Server/$PKT_PATH
unzip zabbix_agent.zip
mv zabbix_agent/zabbix_agent /usr/local/
mv zabbix_agentd/zabbix_agentd /etc/init.d/
useradd zabbix
chmod /etc/init.d/zabbix_agentd
#cp /usr/local/zabbix_agent/sbin/zabbix_agentd /usr/local/sbin/
Server_IP=192.168.19.222
if [[ `ip addr|egrep 'eth.$' | grep -v 'secondary'|tr '/' ' ' |awk '{print $2}'|wc -l` == '' ]]
then
  ListenIP=$(ip addr|egrep 'eth.$'|grep -v 'secondary' | tr '/' ' ' |awk '{print $2}')
  #替换被动模式的ListenIP
  sed -i 's/# ListenIP=0.0.0.0/ListenIP='$ListenIP'/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  #替换Hostname
  sed -i 's/Hostname=192.168.19.203/Hostname='$ListenIP'/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  #添加zabbix服务主机
  sed -i 's/ServerActive=127.0.0.1/ServerActive='$Server_IP'/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  #取消RefreshActiveChecks注释,设置被监控端到服务器获取监控项的周期,默认120S
  sed -i 's/# RefreshActiveChecks=120/RefreshActiveChecks=120/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  # 取消BufferSize注释,设置被监控端存储监控信息的空间大小
  sed -i 's/# BufferSize=100/BufferSize=200 /g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  # 取消Timeout注释,设置被监控端超时时间
  sed -i 's/# Timeout=3/Timeout=3/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  # 取消StartAgents注释,关闭被动模式
  sed -i 's/# StartAgents=3/StartAgents=0/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  #注释掉这行Server,设置纯主动模式
  sed -i 's/Server=192.168.19.222/# Server=192.168.19.222/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  ############# 取消BufferSize注释,设置被监控端存储监控信息的空间大小
  sed -i 's/# HostMetadataItem=/HostMetadataItem='$AOTU_Resgister'/g' /usr/local/zabbix_agent/etc/zabbix_agentd.conf
  fi
#启动服务
service zabbix_agentd start
rm -rf /tmp/zabbix_agent.zip
sed -i ‘/bin\/sh/a\# chkconfig: ’ /etc/init.d/zabbix_agentd
chkconfig zabbix_agentd on

ansible机器执行命令

———————————————————ansible机器

ansible -i h6 h6-m shell -a 'wget
#主动
ftp://172.16.255.22/zabbix/install_agent_active.sh ;bash install_agent_active.sh' -K -become
#被动
ftp://172.16.255.22/zabbix/install_agent_active.sh ;bash install_agent_passive.sh' -K -become
#验证1
ansible -i h6 h6 -m shell -a 'source /etc/profile;/bin/ps -ef |grep zabbix' -K -become

使用ansible结合FTP部署zabbix_agent的更多相关文章

  1. 使用git代替FTP部署代码到服务器的例子

    这篇文章主要介绍了使用git代替FTP部署代码到服务器的例子,这种方法可以节省流量.节省时间,需要的朋友可以参考下 本地开发完成后,通常会在服务器上部署,有人会使用ftp,有人会使用scp, ftp和 ...

  2. Jenkins +svn +maven +tomcat+ ansible 自动化批量部署

    Jenkins +svn +maven +tomcat+ ansible 自动化批量部署 一.部署svn yum install subversion 先创建目录 mkdir /home/svn 创建 ...

  3. ftp部署及使用

    常用软件安装及使用目录 http://www.jb51.net/article/106604.htm   ftp部署 本篇文章主要介绍了CentOS7.0下安装FTP服务的方法,小编觉得挺不错的,现在 ...

  4. FTP ftp部署遇到问题

    FTP  ftp部署遇到问题 一. 二.

  5. Linux上FTP部署:基于mariadb管理虚拟用户

    FTP原理 FTP 采用 Internet 标准文件传输协议 FTP 的用户界面, 向用户提供了一组用来管理计算机之间文件传输的应用程序.图1 FTP 的基本模型 FTP 是基于客户---服务器(C/ ...

  6. Jenkins Ansible GitLab 自动化部署

    Jenkins Ansible GitLab 自动化部署 DevOps https://www.cnblogs.com/yangjianbo/articles/10393765.html https: ...

  7. Ansible 系统概述与部署

    Ansible 系统概述 Ansible是一款为类Unix系统开发的自由开源的配置和自动化工具.它用Python写成,类似于saltstack和Puppet但是有一个不同和优点是我们不需要在节点中安装 ...

  8. Jenkins+Ansible+Gitlab自动化部署三剑客-Ansible本地搭建

    可以通过git bash连接linux 关闭防火墙,禁用防火墙开机启动,并更爱selinux文件,重启 重新登录并检查禁用 getenforce 安装git yum -y install git ns ...

  9. ansible的安装部署及简单应用

    Ansible 是一个配置管理和应用部署工具,功能类似于目前业界的配置管理工具 Chef,Puppet,Saltstack.Ansible 是通过 Python 语言开发.Ansible 平台由 Mi ...

随机推荐

  1. P2709 小B的询问-莫队

    思路 :依旧是 分块 块内按照 r 排序 不同块按照 L排序,处理好增加 删除对结果的影响即可. #include<bits/stdc++.h> using namespace std; ...

  2. shell编程第五天

  3. re模块、hashlib模块

    一.re模块 1.什么是正则? 正则就是用一系列具有特殊含义的字符组成一套规则,该规则用来描述具有某一特征的字符串,正则就是用来去一个大的字符串中匹配出符合规则的子字符串 2.为何要用正则? 用户注册 ...

  4. 把存储过程结果集SELECT INTO到临时表

    把存储过程结果集SELECT INTO到临时表 在开发过程中,很多时候要把结果集存放到临时表中,常用的方法有两种. 一. SELECT INTO . 使用select into会自动生成临时表,不需要 ...

  5. 给有C或C++基础的Python入门 :Python Crash Course 5 if语句

    本章就是Pyhon版的 if语句.原理大家都懂,就不一一说说明了. 值得注意的两点: 1. 在每个if类语句结尾必须加上符号“:”. 2. 注意,在python中是否缩进代表与上一行代码是否有关. 下 ...

  6. 数组中&a与&a[0]的区别 转载自http://blog.csdn.net/FX677588/article/details/74857473

    在探讨这个问题之前,我们首先来看一道笔试题,如下: [摘自牛客网]下列代码的结果是:(正确答案是 C) main() { int a[5]={1,2,3,4,5}; int *ptr=(int *)( ...

  7. [P1020]导弹拦截 (贪心/DP/二分/单调队列)

    一道很经典的题 这道题就是要求一个最长单调不升子序列和一个最长单调上升子序列. 先打了一个n2复杂度的 用DP #include<bits/stdc++.h> using namespac ...

  8. 树莓派mariadb折腾

    今天在树莓派之中安装mysql,结果被我安装了mariadb,这样做很讨厌,但是也可以将就用.记录一下折腾的过程. 安装就还是使用sudo apt install mysql 1.安装之后需要使用工具 ...

  9. C. Playing Piano 动态规划

    题目意思是给你一个n长度的数字串为a,让你构造一个n长度的数字串b值都为1-5满足以下条件: 正常的dfs暴力构造会超时,我试过了.. 可以开一个二维数组dp[i][j]用来表示b的第i个数字为j是否 ...

  10. pygame 笔记-9 图片旋转及边界反弹

    h5或flash中,可以直接对矢量对象,比如line, rectange旋转,但是pygame中,仅支持对image旋转,本以为这个是很简单的事情,但是发现还是有很多小猫腻的,记录一下: 先看一个错误 ...