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

CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统,第1张

CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统 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

木偶装置

1.服务器安装傀儡服务器。

Puppet不在CentOS的基础源码中,所以需要加入PuppetLabs提供的官方源码。puppet-server安装在PuppetMaster服务器上,相关的依赖包如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


傀儡主服务器配置

1.配置自动身份验证

允许redking.com域中的所有主机自动颁发证书。创建autosign.conf文件

[root@master ~]# cat > /etc/puppet/autosign.conf <<EOF > *.redking.com > EOF [root@master ~]#


傀儡代理客户端配置

1.修改客户端主配置文件puppet.conf,增加监控,指定服务器域名。

[root@agent ~]# vim /etc/puppet/puppet.conf  [agent]         listen = true         server = master.redking.com


木偶测试

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

客户端需要向服务器发送请求来管理客户端。这实际上是一个证书颁发过程。当puppet客户机第一次运行时,会生成一个SSL证书并发送给Puppet服务器。如果服务器同意管理客户端,它将颁发证书。您可以使用此命令来颁发证书。因为我们已经在客户机中设置了服务器地址,所以我们不需要为服务器寻址。

[root@agent ~]# puppet agent --test


为了更好的了解当天之后的注册流程和错误,可以添加参数。

–No-daemon前台输出日志
–详细输入更详细的日志
–调试更详细的日志,在调试时使用

[root@agent ~]# puppet agent --no-daemonize --onetime --verbose --debug

检查服务器的证书颁发信息。

[root@master ~]# puppet cert list --all

Zabbix服务器安装

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 < schema.sql [root@master create]# mysql -uroot -p123456 zabbix < p_w_picpaths.sql [root@master create]# mysql -uroot -p123456 zabbix < data.sql


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

Zabbix安装页面:http://zabbix.redking.com/zabbix/setup.php

Zabbix背景界面

编写Zabbix模块

1.创建模块目录。

[root@master ~]# mkdir -p /etc/puppet/modules/zabbix/{manifests,templates}

2.创建清单文件

服务器存储客户机服务器的所有配置代码,这些代码在puppet中称为manifest。客户端下载manifest后,可以根据manifest对服务器进行配置,如软件包管理、用户管理、文件管理等。

Zabbix代理程序使用官方软件源码,客户端配置文件通过模板下载。由于客户端需要指定Zabbix服务器,配置文件通过变量传递,最后“-->”指定资源之间的依赖顺序关系。

[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=<%= zabbix_server %> Hostname=<%= fqdn %> ListenIP=<%= ipaddress %> 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

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

ZabbixWeb界面测试

设置发现规则

设置动作

监控界面

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

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/783816.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-04
下一篇 2022-05-04

发表评论

登录后才能评论

评论列表(0条)

保存