当前位置:首页 >综合 >【博文推荐】CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统 将配置文件应用到所有服务器

【博文推荐】CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统 将配置文件应用到所有服务器

2024-07-02 12:27:04 [百科] 来源:避面尹邢网

【博文推荐】CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统

作者:redking 运维 系统运维 分布式 编者按:如题,博文作者通过最新版的推荐统CentOS6.6和Puppet3.7.3分布式去部署Zabbix2.4的监控系统,这篇非常具有挑战性的分布内容会让您深刻的体会到Puppet的强悍!

本博文出自51CTO博客redking博主,式部署有任何问题请进入博主页面互动讨论!控系
博文地址:http://redking.blog.51cto.com/27212/1604984
OS:CentOS-6.6-x86_64(Minimal)Puppet 3.7.3Zabbix 2.4Puppet/Zabbix master: master/zabbix.redking.comPuppet/Zabbix agent:  agent1~5.redking.com

Puppet安装

【博文推荐】CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统 将配置文件应用到所有服务器

1.服务端安装puppet-server

【博文推荐】CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统 将配置文件应用到所有服务器

puppet不在CentOS的博文基本源中,需要加入PuppetLabs提供的推荐统官方源,Puppet Master服务器端安装puppet-server,分布自动匹配安装Facter等相关依赖包

【博文推荐】CentOS6.6+Puppet3.7.3分布式部署Zabbix2.4监控系统 将配置文件应用到所有服务器

[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 <<EOF> *.redking.com> EOF[root@master ~]#

Puppet Agent客户端配置

1.修改客户端主配置文件puppet.conf来增加监听与指定服务端域名

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

clipboard

Puppet测试

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

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

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

clipboard[1]  

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

–no-daemonize 前台输出日志  

–verbose 输入更加详细的日志  

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

–test 表示测试,就带一个–test参数就可以

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

服务端查看证书签发信息

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

clipboard[2]

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

3.修改Zabbix配置文件配置数据库相关信息

[root@master ~]# vim /etc/zabbix/zabbix_server.confDBHost=localhostDBName=zabbixDBUser=zabbixDBPassword=zabbix

4.设置PHP默认时区

[root@master ~]# vim /etc/php.inidate.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

clipboard[3]

clipboard[4]

Zabbix后台界面

clipboard[5]

#p#

编写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.ppclass 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.erbPidFile=/var/run/zabbix/zabbix_agentd.pidLogFile=/var/log/zabbix/zabbix_agentd.logEnableRemoteCommands=1LogRemoteCommands=1Server=<%= 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.ppnode /^agent\d+\.redking\.com$/ { $zabbix_server = "zabbix.redking.com"include zabbix}

5.修改site.pp将测试节点载入Puppet

[root@master ~]# vim /etc/puppet/manifests/site.ppPackage { allow_virtual => true,}import "nodes/agentgroup.pp"

节点agent.redking.com测试

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

clipboard[6]

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

#p#

Zabbix Web界面测试

设置Discovery规则

clipboard[7]

设置Actions

clipboard[8]

clipboard[9]

Monitoring界面

clipboard[10]

clipboard[11]

clipboard[12]

clipboard[13]

clipboard[14]

clipboard[15]

clipboard[16]

clipboard[17]

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

责任编辑:林师授 来源: 51CTO ZabbixPuppet

(责任编辑:娱乐)

    推荐文章
    热点阅读