设为首页 收藏本站
查看: 1379|回复: 0

[经验分享] CentOS+Puppet分布式部署Zabbix监控系统

[复制链接]

尚未签到

发表于 2015-9-9 10:21:53 | 显示全部楼层 |阅读模式
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等相关依赖包

[iyunv@master ~]# rpm -ivh http://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm
[iyunv@master ~]# yum install -y puppet-server
[iyunv@master ~]# chkconfig puppetmaster on
[iyunv@master ~]# service puppetmaster start
  2.客户端安装puppet

[iyunv@agent ~]# rpm -ivh http://yum.puppetlabs.com/el/6/products/x86_64/puppetlabs-release-6-7.noarch.rpm
[iyunv@agent ~]# yum install -y puppet
[iyunv@agent ~]# chkconfig puppet on
[iyunv@agent ~]# service puppet start
  Puppet Master服务器配置
  1.配置自动认证
  允许所有redking.com域的主机自动颁发证书.创建autosign.conf文件

[iyunv@master ~]# cat > /etc/puppet/autosign.conf <<EOF
> *.redking.com
> EOF
[iyunv@master ~]#
  Puppet Agent客户端配置
  1.修改客户端主配置文件puppet.conf来增加监听与指定服务端域名

[iyunv@agent ~]# vim /etc/puppet/puppet.conf
[agent]
listen = true
server = master.redking.com
DSC0000.jpg
  Puppet测试
  这样我们可以使用Puppet来管理Puppet,通过配置puppet modules的方式来管理所有puppet客户端,将配置文件应用到所有服务器。
  client需要向服务器端发出请求, 让服务器对客户端进行管理. 这其实是一个证书签发的过程. 第一次运行 puppet 客户端的时候会生成一个SSL证书并指定发给Puppet 服务端, 服务器端如果同意管理客户端,就会对这个证书进行签发,可以用这个命令来签发证书,由于我们已经在客户端设置了server地址,因此不需要跟服务端地址
  为了详细了解注册的过程和日后排错,可以增加参数,因为配置文件里

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

DSC0001.jpg
  �no-daemonize 前台输出日志
  �verbose 输入更加详细的日志
  �debug 更加详细的日志,排错的时候使用
  �test 表示测试,就带一个�test参数就可以

[iyunv@agent ~]# puppet agent --no-daemonize --onetime --verbose --debug
  服务端查看证书签发信息

[iyunv@master ~]# puppet cert list --all
DSC0002.jpg
  Zabbix Server安装
  1.配置软件仓库并安装Zabbix

[iyunv@master ~]# rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm
[iyunv@master ~]# yum install -y zabbix-server-mysql zabbix-web-mysql mysql-server
  默认创建Zabbix运行的用户及组,创建Web服务器Apache虚拟主机配置文件。
  2.创建数据库并导入数据表

[iyunv@master ~]# rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm
[iyunv@master ~]# yum install -y zabbix-server-mysql zabbix-web-mysql mysql-server
[iyunv@master ~]# service mysqld start
[iyunv@master ~]# chkconfig mysqld on
[iyunv@master ~]# mysqladmin -u root password '123456'
[iyunv@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数据库文件目录导入数据库信息

[iyunv@master ~]# cd /usr/share/doc/zabbix-server-mysql-2.4.3/create/
[iyunv@master create]# mysql -uroot -p123456 zabbix < schema.sql
[iyunv@master create]# mysql -uroot -p123456 zabbix < images.sql
[iyunv@master create]# mysql -uroot -p123456 zabbix < data.sql
  3.修改Zabbix配置文件配置数据库相关信息

[iyunv@master ~]# vim /etc/zabbix/zabbix_server.conf
DBHost=localhost
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
  4.设置PHP默认时区

[iyunv@master ~]# vim /etc/php.ini
date.timezone = PRC
  5.启动Zabbix和Apache服务

[iyunv@master ~]# service zabbix-server start
[iyunv@master ~]# chkconfig zabbix-server on
[iyunv@master ~]# service httpd start
[iyunv@master ~]# chkconfig httpd on
  6.设置Zabbix
  Zabbix安装页面: http://zabbix.redking.com/zabbix/setup.php
DSC0003.jpg
DSC0004.jpg
  Zabbix后台界面
DSC0005.jpg
  编写Zabbix模块
  1.创建模块目录

[iyunv@master ~]# mkdir -p /etc/puppet/modules/zabbix/{manifests,templates}
  2.创建manifests文件
  服务器端保存着所有对客户端服务器的配置代码,在puppet里面叫做manifest. 客户端下载manifest之后,可以根据manifest对服务器进行配置,例如软件包管理,用户管理和文件管理等等。
  Zabbix Agent程序采用官方提供的软件源,客户端配置文件采用模板方式进行文件下载,由于客户端需要指定Zabbix Server,因此配置文件采用变量进行传递,最后使用“->”指定资源之间的依赖顺序关系。

[iyunv@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.创建模板文件

[iyunv@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.创建节点文件

[iyunv@master ~]# mkdir /etc/puppet/manifests/nodes
[iyunv@master ~]# vim /etc/puppet/manifests/nodes/agentgroup.pp
node /^agent\d+\.redking\.com$/ {
$zabbix_server = "zabbix.redking.com"
include zabbix
}
  5.修改site.pp将测试节点载入Puppet

[iyunv@master ~]# vim /etc/puppet/manifests/site.pp
Package {
allow_virtual => true,
}
import "nodes/agentgroup.pp"
  节点agent.redking.com测试

[iyunv@agent ~]# puppet agent --test
DSC0006.jpg
  客户端已经自动安装zabbix-agent并开启服务。
  Zabbix Web界面测试
  设置Discovery规则
DSC0007.jpg
  设置Actions
DSC0008.jpg
DSC0009.jpg
  Monitoring界面
DSC00010.jpg
DSC00011.jpg
DSC00012.jpg
DSC00013.jpg
DSC00014.jpg
DSC00015.jpg
DSC00016.jpg
DSC00017.jpg


  • 本文来自:Linux学习教程网

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-111374-1-1.html 上篇帖子: Zabbix探索:网络设备监控1 下篇帖子: Zabbix系列学习笔记之一:Zabbix的特点及主要优势
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表