$ppclass php,CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统

本文介绍了如何在CentOS 6.6环境下利用Puppet自动化部署Zabbix监控系统。首先,配置Puppet Master和Agent,实现自动认证和证书签发。接着,安装Zabbix Server和Agent,配置数据库,启动相关服务。最后,通过Puppet管理Zabbix Agent,并创建自定义模块以自动化配置。
摘要由CSDN通过智能技术生成

OS:CentOS-6.6-x86_64(Minimal)

Puppet 3.7.3

Zabbix 2.4

Puppet/Zabbix master: master/zabbix.redking.com

Puppet/Zabbix agent:  agent1~5.redking.com

Puppet安装

1.服务端安装puppet-server

puppet不在CentOS的基本源中,需要加入PuppetLabs提供的官方源,Puppet Master服务器端安装puppet-server,自动匹配安装Facter等相关依赖包[root@master ~]# rpm -ivh http://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm

[root@master ~]# yum install -y puppet-server

[root@master ~]# chkconfig puppetmaster on

[root@master ~]# service puppetmaster start

2.客户端安装puppet[root@agent ~]# rpm -ivh http://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm

[root@agent ~]# yum install -y puppet

[root@agent ~]# chkconfig puppet on

[root@agent ~]# service puppet start

Puppet Master服务器配置

1.配置自动认证

允许所有redking.com域的主机自动颁发证书.创建autosign.conf文件[root@master ~]# cat > /etc/puppet/autosign.conf <

> *.redking.com

> EOF

[root@master ~]#

Puppet Agent客户端配置

1.修改客户端主配置文件puppet.conf来增加监听与指定服务端域名[root@agent ~]# vim /etc/puppet/puppet.conf

[agent]

listen = true

server = master.redking.com

df8e7b42d2f5737b48ce250ffab11561.png

Puppet测试

这样我们可以使用Puppet来管理Puppet,通过配置puppet modules的方式来管理所有puppet客户端,将配置文件应用到所有服务器。

client需要向服务器端发出请求, 让服务器对客户端进行管理. 这其实是一个证书签发的过程. 第一次运行 puppet 客户端的时候会生成一个SSL证书并指定发给Puppet 服务端, 服务器端如果同意管理客户端,就会对这个证书进行签发,可以用这个命令来签发证书,由于我们已经在客户端设置了server地址,因此不需要跟服务端地址[root@agent ~]# puppet agent --test

655347559b9857ef04f5ed535e25d7ed.png

为了详细了解注册的过程和日后排错,可以增加参数

–no-daemonize 前台输出日志

–verbose 输入更加详细的日志

–debug 更加详细的日志,排错的时候使用

–test 表示测试,就带一个–test参数就可以[root@agent ~]# puppet agent --no-daemonize --onetime --verbose --debug

服务端查看证书签发信息[root@master ~]# puppet cert list --all

be58939e0da02e8fbcd80b6f9f5003f5.png

Zabbix Server安装

1.配置软件仓库并安装Zabbix[root@master ~]# rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm

[root@master ~]# yum install -y zabbix-server-mysql zabbix-web-mysql mysql-server

默认创建Zabbix运行的用户及组,创建Web服务器Apache虚拟主机配置文件。

2.创建数据库并导入数据表[root@master ~]# rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm

[root@master ~]# yum install -y zabbix-server-mysql zabbix-web-mysql mysql-server

[root@master ~]# service mysqld start

[root@master ~]# chkconfig mysqld on

[root@master ~]# mysqladmin -u root password '123456'

[root@master ~]# mysql -uroot -p123456

mysql> create database zabbix character set utf8;

mysql> grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';

mysql> flush privileges;

进入Zabbix数据库文件目录导入数据库信息[root@master ~]# cd /usr/share/doc/zabbix-server-mysql-2.4.3/create/

[root@master create]# mysql -uroot -p123456 zabbix 

[root@master create]# mysql -uroot -p123456 zabbix 

[root@master create]# mysql -uroot -p123456 zabbix 

3.修改Zabbix配置文件配置数据库相关信息[root@master ~]# vim /etc/zabbix/zabbix_server.conf

DBHost=localhost

DBName=zabbix

DBUser=zabbix

DBPassword=zabbix

4.设置PHP默认时区[root@master ~]# vim /etc/php.ini

date.timezone = PRC

5.启动Zabbix和Apache服务[root@master ~]# service zabbix-server start

[root@master ~]# chkconfig zabbix-server on

[root@master ~]# service httpd start

[root@master ~]# chkconfig httpd on

6.设置Zabbix

959b179cb84d32741e90ab3da893910a.png

08a135f589705b7ece1b3daf77896fd3.png

Zabbix后台界面

3e847dd1481b565e65822aac72e24429.png

编写Zabbix模块

1.创建模块目录[root@master ~]# mkdir -p /etc/puppet/modules/zabbix/{manifests,templates}

2.创建manifests文件

服务器端保存着所有对客户端服务器的配置代码,在puppet里面叫做manifest. 客户端下载manifest之后,可以根据manifest对服务器进行配置,例如软件包管理,用户管理和文件管理等等。

Zabbix Agent程序采用官方提供的软件源,客户端配置文件采用模板方式进行文件下载,由于客户端需要指定Zabbix Server,因此配置文件采用变量进行传递,最后使用“->”指定资源之间的依赖顺序关系。[root@master ~]# vim /etc/puppet/modules/zabbix/manifests/init.pp

class zabbix {

package { 'zabbix-agent':

ensure => installed,

require => Yumrepo["zabbix"],

}

yumrepo { 'zabbix':

baseurl => "http://repo.zabbix.com/zabbix/2.4/rhel/\$releasever/\$basearch/",

descr => "Zabbix Official Repository",

enabled => 1,

gpgcheck => 0,

}

file { '/etc/zabbix/zabbix_agentd.conf':

content => template("zabbix/zabbix_agentd_conf.erb"),

ensure => file,

}

service { 'zabbix-agent':

ensure => "running",

hasstatus => true,

enable => true,

subscribe => [ File["/etc/zabbix/zabbix_agentd.conf"] ],

}

Package ["zabbix-agent"] -> File ["/etc/zabbix/zabbix_agentd.conf"] -> service ["zabbix-agent"]

}

3.创建模板文件[root@master ~]# vim /etc/puppet/modules/zabbix/templates/zabbix_agentd_conf.erb

PidFile=/var/run/zabbix/zabbix_agentd.pid

LogFile=/var/log/zabbix/zabbix_agentd.log

EnableRemoteCommands=1

LogRemoteCommands=1

Server=

Hostname=

ListenIP=

Include=/etc/zabbix/zabbix_agentd.d/

4.创建节点文件[root@master ~]# mkdir /etc/puppet/manifests/nodes

[root@master ~]# vim /etc/puppet/manifests/nodes/agentgroup.pp

node /^agent\d+\.redking\.com$/ {

$zabbix_server = "zabbix.redking.com"

include zabbix

}

5.修改site.pp将测试节点载入Puppet[root@master ~]# vim /etc/puppet/manifests/site.pp

Package {

allow_virtual => true,

}

import "nodes/agentgroup.pp"

节点agent.redking.com测试[root@agent ~]# puppet agent --test

c1da61eb013e50e8a42517fa5a444dc1.png

客户端已经自动安装zabbix-agent并开启服务。

Zabbix Web界面测试

设置Discovery规则

b53035ead794eed3a42e4de202c53d61.png

设置Actions

ca2946f418dc2fbc88a3fe2c7e7d0ce1.png

fcb4b82436642a367ae3b969b875dcf2.png

Monitoring界面

8b4058e39ad09dcfd0ac5b81508f5cae.png

3d2b0cc692c7f7a73d7fabe976269120.png

fc86ad38f6b56a5f42be5f6c9083546b.png

2c8b46d724b4ec195813f20c32422f52.png

277e3e6f070944e2f23dd4cf46d37a2b.png

64acba9622a5b7bf39eb51549b9cf1c3.png

873728f4215bb20dcbe22bba95299e00.png

6dac41e546db2ce260d4f2f3721590c0.png

==================================END=============================

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值