您的位置:首页 > 运维架构

zabbix监控之同时向多人邮件报警,zabbix监控之自定义监控项目, 使用Zatree来一览Zabbix图表

2014-08-22 21:36 1501 查看
zabbix邮件报警配置步骤说明: 1、 准备一个发送邮件的脚本 2、 修改zabbix配置文件中指定的脚本路径3、关联脚本名称4、用户设置收件邮箱与报警时间5、配置报警触发器6、添加多个用户,同时给多个人发邮件7、邮件接收测试

1、准备一个发送邮件的脚本

发送邮件有很多方法,自己写脚本的话,只要遵循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 ='yangrong@qssec.com'
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即可。

2、修改zabbix配置文件中指定的脚本路径

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下的名称一致。


4、用户设置收件邮箱与报警时间

【zabbix主面板à管理à用户à点击用户】


配置用户对应的邮箱

5、配置报警触发器

【zabbix主面板à组态à动作à创建动作】 配置报警信息


配置报警触发条件

配置触发条件后的接收用户

6、添加多个用户,同时给多个人发邮件

首先在【管理】à【用户】à创建普通用户然后把普通用户提升为超级管理员。如果不提升为超级管理员,普通用户是没有发送邮件的权限的!

在【组态】à【动作】中添加新的接收用户。

7、邮件接收测试

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文件中定义UserParameter3、在界面配置item,通过键值来控制传参4、查看监控数据情况5、配置触发器,用来报警6、宕服务测试 对于zabbix的安装与邮件报警设置,可参考两篇文章。/article/6918038.html zabbix监控之基于LNMP环境安装/article/6918037.html zabbix监控之同时向多人邮件报警

1、编写进程监控脚本,获取监控项的具体值

进程监控脚本构思:根据名称或端口号来判定该程序是否存在。如果传参包含端口号,则根据端口号判断进程,有返回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()

2、在zabbix_agentd.conf文件中定义UserParameter

在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]测试可用,接下来在主界面配置监控

3、在界面配置item,通过键值来控制传参

【组态】à【主机】à【项目】à【创建监控项】此处键值的用法和zabbix_agentd.conf中定义的UserParameter一致。


4、查看监控数据情况

【监控中】à【最新数据】 最新数据为1,监控正常。

5、配置触发器,用来报警

【组态】à【主机】à【触发器】à【创建触发器】


6、宕服务测试

在agent client端,宕掉mysql。邮箱1分钟后收到报警。

成功收到报警邮件,自定义监控及报警配置完成。
参考:/article/6918037.html

使用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插件优化:优化左侧边栏/article/4393888.html 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);
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: