zabbix邮件报警配置步骤说明:
1、 准备一个发送邮件的脚本
2、 修改zabbix配置文件中指定的脚本路径
3、关联脚本名称
4、用户设置收件邮箱与报警时间
5、配置报警触发器
6、添加多个用户,同时给多个人发邮件
7、邮件接收测试
发送邮件有很多方法,自己写脚本的话,只要遵循zabbix传参的格式即可。
zabbix发送邮件传参格式:./sendmail.py 收件人 标题 邮件内容
python发送邮件脚本如下:
cat /usr/local/zabbix/share/zabbix/alertscripts/sendmail_qs.py
#!/usr/bin/python # -*- coding:utf-8 -*- import smtplib import sys from email.mime.text importMIMEText import time #reload(sys) #sys.setdefaultencoding('utf8') current_time=time.strftime('%Y-%m-%d%H:%M',time.localtime(time.time())) mail_host ='smtp.exmail.qq.com' mail_user ='[email protected]' mail_pwd = '******' def send_email( content,mailto, get_sub ): #msg = MIMEText( content.encode('utf8'),_subtype = 'html', _charset = 'utf8') msg = MIMEText(content,_subtype='plain',_charset='gb2312') msg['From'] = mail_user msg['Subject'] =get_sub msg['To'] = ",".join( mailto ) try: s = smtplib.SMTP_SSL( mail_host, 465) s.login(mail_user, mail_pwd ) s.sendmail(mail_user, mailto,msg.as_string()) s.close() except Exception as e: print 'Exception: ', e title=sys.argv[2] cont=""" --------------------------------- 摘要: %s --------------------------------- 时间: %s --------------------------------- """%(sys.argv[3],current_time) to_list = [ '%s'%(sys.argv[1]), ] withopen('/tmp/sendmail_qs.log','ab') as f: f.write('%s Receive address: %s Title: %s \n'%(current_time,sys.argv[1],title)) send_email( cont, to_list,title)
#该python脚本最后把发送邮件的日志记录到/tmp/sendmail.log中。
#如若自己使用,修改上方mail_host,mail_user,mail_pwd即可。
echo 'AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts' >>/usr/local/zabbix/etc/zabbix_server.conf /etc/init.d/zabbix_serverrestart
本例安装zabbix安装目录在/usr/local/zabbix,不同路径手动修改即可。
3、关联脚本名称
【zabbix主面板à管理à示警媒介类型à创建媒体类型】
输入脚本名称和/usr/local/zabbix/share/zabbix/alertscripts下的名称一致。
【zabbix主面板à管理à用户à点击用户】
配置用户对应的邮箱
【zabbix主面板à组态à动作à创建动作】 配置报警信息
配置报警触发条件
配置触发条件后的接收用户
首先在【管理】à【用户】à创建普通用户
然后把普通用户提升为超级管理员。如果不提升为超级管理员,普通用户是没有发送邮件的权限的!
在【组态】à【动作】中添加新的接收用户。
down掉client节点的zabbix_agentd进程。等待邮件报警,默认agent发邮件是5分钟,即5次没有获取到数据则报警。
经测试,zabbix给多个人员发送邮件时,并不是采取并发邮件的方式。而是执行两次发送邮件的脚本,即每一次一个收件人,而不是一次性有多个收件人。
所以若收件人数量多的话,直接把收件人全部写到上述python发邮件脚本中,即不调用zabbix传过来的收件人,缺点就是收件人变更时也需要手动来改python脚本,而不是改zabbix用户配置。
到此zabbix多人邮件报警配置完成。
zabbix监控之自定义监控项目
zabbix搭建好后,除了调用默认的模板,还要监控其它常用的进程,有redis,rsync,nginx,gunicorn,mysql等等都要进行监控。
自定义监控的配置过程如下:
1、编写进程监控脚本,获取监控项的具体值
2、在zabbix_agentd.conf文件中定义UserParameter
3、在界面配置item,通过键值来控制传参
4、查看监控数据情况
5、配置触发器,用来报警
6、宕服务测试
对于zabbix的安装与邮件报警设置,可参考两篇文章。
http://yangrong.blog.51cto.com/6945369/1541810 zabbix监控之基于LNMP环境安装
http://yangrong.blog.51cto.com/6945369/1541822 zabbix监控之同时向多人邮件报警
进程监控脚本构思:
根据名称或端口号来判定该程序是否存在。
如果传参包含端口号,则根据端口号判断进程,有返回1,没有返回0。
如果不包含端口号,根据进程名判断进程,有返回1,没有返回0。
注:所编写的脚本只需要输出具体值即可,无须像nagios那样返回退出值,描述信息等。
[root@yang python]# catprocess_port.py #!/usr/bin/python #function:check process_nameor check process_port import os,sys,commands def help(): print "Usage: " print " %s process_name [process_port]"%sys.argv[0] print "Example: " print " %s mysql ;If the process_nameexists, output 1, otherwise 0"%sys.argv[0] print " %s nginx 80 ;If the process_port exists, output 1,otherwise 0"%sys.argv[0] print " %s mysql 3306 "%sys.argv[0] def check_process_name(): process_num=commands.getstatusoutput("ps -ef|grep -v grep|grep -v%s|grep -v '\[%s\]'|grep %s|wc -l "%(sys.argv[0],sys.argv[1],sys.argv[1])) #print process_num if not process_num[1]: print "0" return if int(process_num[1]) >= 1: print "1" else: print "0" def check_process_port(): process_num=commands.getstatusoutput("netstat -lnt|grep -v grep|grep ':%s '|wc -l"%sys.argv[2]) if int(process_num[1]) >=1: print "1" else: print "0" ###start execute if len(sys.argv) == 2: check_process_name() sys.exit() elif len(sys.argv) == 3: check_process_port() sys.exit() else: help() sys.exit()
在zabbix agent端修改zabbix_agentd.conf文件:
用户参数=键值[*],命令
echo 'UserParameter =check_process[*],/usr/bin/python /python/process_port.py $1 $2 ' >>/usr/local/zabbix/etc/zabbix_agentd.conf #添加用户参数
/etc/init.d/zabbix_agentdrestart #重启zabbixagent服务
agent端本机测试:
在中括号中内容为传参内容,如果要传参多个,用逗号隔开,第一个则是$1,第二个则是$2。
[root@yang python]#/usr/local/zabbix/sbin/zabbix_agentd -t check_process[hello]
check_process[hello] [t|0]
#返回结果为0,代表hello进程不存在。
[root@yang python]#/usr/local/zabbix/sbin/zabbix_agentd -t check_process[mysql]
check_process[mysql] [t|1]
#返回结果为1,代表mysql进程存在。
[root@yang python]#/usr/local/zabbix/sbin/zabbix_agentd -t check_process[mysql,3306]
check_process[mysql,3306] [t|1]
测试可用,接下来在主界面配置监控
【组态】à【主机】à【项目】à【创建监控项】
此处键值的用法和zabbix_agentd.conf中定义的UserParameter一致。
【监控中】à【最新数据】 最新数据为1,监控正常。
【组态】à【主机】à【触发器】à【创建触发器】
在agent client端,宕掉mysql。邮箱1分钟后收到报警。
成功收到报警邮件,自定义监控及报警配置完成。
参考:http://yangrong.blog.51cto.com/6945369/1541822
使用Zatree来一览Zabbix图表
zatree 是来自国内58同城开发的监控软件zabbix的一个插件,主要功能是提供host group的树形展示和在item里指定关键字查询及数据排序。
http://yunpan.cn/cQV2eBnFGKEpz 访问密码 5620
1:下载文件
[root@zabbix ~]# yum -y install git [root@zabbix ~]# git clone https://github.com/spide4k/zatree.git zatree
2、复制相关文件
下载好的文件在当前目录下的zatree目录,选择您正在使用的zabbix版本,比如我的是2.0.6版本
[root@zabbix ~]#mv zatree/zabbix-2.0.x/ /usr/local/nginx/html/zatree/
[root@zabbix ~]
# cd /var/www/html/zabbix/zatree/addfile/
[root@zabbix addfile]
# cp class.cchart_zabbix.php class.cgraphdraw_zabbix.php class.cimagetexttable_zabbix.php /var/www/html/zabbix/include/classes/
[root@zabbix addfile]
# cp zabbix.php zabbix_chart.php /var/www/html/zabbix/
[root@zabbix addfile]
# cp CItemValue.php /var/www/html/zabbix/api/classes/
3、支持web interface,修改配置文件
[root@zabbix ~]# cat /var/www/html/zabbix/zatree/zabbix_config.php <?php global $zabbix_api_config; $zabbix_api_config=array( 'api_url'=>'api_jsonrpc.php', 'user'=>'Admin', //web登陆的用户名 'passowrd'=>'zabbix', //web登陆的密码 'graph_url'=>'zabbix_chart.php', ); ?>
4:导航增加Zatree入口,修改menu.inc.php,main.js
[root@zabbix ~]# vim /var/www/html/zabbix/include/menu.inc.php +283 #在283行后也就是284行后加如下信息,切勿重复 'zatree'=>array( 'label' => _('Zatree'), 'user_type' => USER_TYPE_ZABBIX_USER, 'default_page_id' => 0, 'force_disable_all_nodes' => true, 'pages' =>array( array('url' => 'zabbix.php','label' => _('Zatree'),) ) ), 'login' => array( 'label' => _('Login'), 'user_type' => 0, 'default_page_id' => 0,
[root@zabbix ~]# vim /var/www/html/zabbix/js/main.js +106 #替换106行 menus: {'empty': 0, 'view': 0, 'cm': 0, 'reports': 0, 'config': 0, 'admin': 0, 'zatree':0},
5、增加封装的api类
[root@zabbix ~]# vim /var/www/html/zabbix/include/classes/api/API.php +74 #添加一行参数 'usermedia' => 'CUserMedia', 'itemvalue'=>'CItemValue', 'webcheck' => 'CWebCheck' );
6:登陆zabbix,在导航里可以看到一个Zatree的菜单,使用方法是傻瓜的,图形是自动添加罗列起来的。
7、 如果你的主机名都是ip,并且向排序显示,解决方法: 编辑zabbix_ajax.php 43行代码注释44打开,不支持ip排序,43行代码打开44行注释,支持ip排序
43 $new_list[ip2long($each_host->host)]=$each_host;
44 //$new_list[] = $each_host;
zatree插件优化:优化左侧边栏
http://qicheng0211.blog.51cto.com/3958621/1531637
zatree项目地址https://github.com/spide4k/zatree ,安装方法进到不同版本目录看readme。
又发现zatree的一个小问题:在zabbix_config.php配置Admin和密码后,任何普通用户在zatree的左侧栏能看到所有的主机组列表,包括没有权限的那些主机组。
zatree是用zabbix_config.php中配置的用户和密码来获取主机组列表的,因为配置的是Admin超级用户,自然能获取到全部的主机组了。
因此优化了zatree左侧边栏,使普通用户只能看到属于自己的主机组列表。原理是zabbix_ajax.php获取cookie中的sessionid,通过这个sessionid获取登录用户的主机组列表。
修改方法如下,这里针对zatree的zabbix-2.2.x版本做修改,方法同样适合zabbix-2.0.x版本:
进入zatree目录,修改以下两个文件:
第一步:zabbix_ajax.php
传递$_COOKIE['zbx_sessionid']给hostgroupGet(),获取当前用户具有readable权限的主机组列表。
vim /var/www/html/zabbix/zatree
$groups = $zabbixApi->hostgroupGet(array("output" => "extend", "monitored_hosts" => true));
修改为:
if(isset($_COOKIE['zbx_sessionid'])){ $groups = $zabbixApi->hostgroupGet(array("output" => "extend", "monitored_hosts" => true), '', $_COOKIE['zbx_sessionid']); } else { $groups = $zabbixApi->hostgroupGet(array("output" => "extend", "monitored_hosts" => true)); }
第二步:ZabbixApiAbstract.class.php
修改2594行hostgroupGet方法,添加$sessionid形参。当传入$sessionid参数时,设置$this->auth的值为$sessionid。
vim /var/www/html/zabbix/zatree/ZabbixApiAbstract.class.php
public function hostgroupGet($params=array(), $arrayKeyProperty='') { // get params array for request $params = $this->getRequestParamsArray($params); // request return $this->request('hostgroup.get', $params, $arrayKeyProperty); }
修改为
public function hostgroupGet($params=array(), $arrayKeyProperty='', $sessionid='') { // get params array for request $params = $this->getRequestParamsArray($params); // request if (isset($sessionid)) $this->auth = $sessionid; return $this->request('hostgroup.get', $params, $arrayKeyProperty); }