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

wKiom1PyL8HCvKoxAAG6A110IL4944.jpg

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

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

wKioL1PyMNmh43vGAAHc8MYsLQQ203.jpg


配置用户对应的邮箱

wKioL1PyMY_D8HMeAADko0AJD4o971.jpg

  

5、配置报警触发器

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

wKiom1PyL8PRvCBZAAMSWbcmK9Q825.jpg


 

配置报警触发条件

wKioL1PyMN3iQguLAAICe_vaWu0045.jpg

 

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

wKiom1PyL8bRaeD_AAGhrBMCNHI272.jpg

  

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

首先在【管理】à【用户】à创建普通用户

然后把普通用户提升为超级管理员。如果不提升为超级管理员,普通用户是没有发送邮件的权限的!

wKioL1PyMN-CLpy1AAGwXJRr3ug580.jpg

 

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

wKiom1PyL8iDMUh4AAHGhYxlhhU815.jpg

  

7、邮件接收测试

   downclient节点的zabbix_agentd进程。等待邮件报警,默认agent发邮件是5分钟,即5次没有获取到数据则报警。

   经测试,zabbix给多个人员发送邮件时,并不是采取并发邮件的方式。而是执行两次发送邮件的脚本,即每一次一个收件人,而不是一次性有多个收件人。

   所以若收件人数量多的话,直接把收件人全部写到上述python发邮件脚本中,即不调用zabbix传过来的收件人,缺点就是收件人变更时也需要手动来改python脚本,而不是改zabbix用户配置。

 

wKiom1PyL8nh5JyPAAEiYU1jo10645.jpg

 

wKioL1PyMOKCcr9fAAGTQPp-TZ8101.jpg

到此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、编写进程监控脚本,获取监控项的具体值

进程监控脚本构思:

根据名称或端口号来判定该程序是否存在。

如果传参包含端口号,则根据端口号判断进程,有返回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一致。

wKiom1PzZZiCDl9uAAHwnhd0f7g138.jpg


4、查看监控数据情况

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

wKiom1PzZZiTI-DrAAEyMoVcg1o866.jpg

 

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

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

wKioL1PzZrCxH5bwAAHgeXMgjC4090.jpg 


6、宕服务测试

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

wKioL1PzZrHwQKMHAAGlRhaybyA922.jpg

成功收到报警邮件,自定义监控及报警配置完成。


参考: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.cp_w_picpathtexttable_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的菜单,使用方法是傻瓜的,图形是自动添加罗列起来的。

wKioL1V_6CLQLet4AAJ6DU7F7zM420.jpg7、 如果你的主机名都是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获取登录用户的主机组列表。


wKioL1V_6L3BnzaMAADmZWhFKCM927.jpg

修改方法如下这里针对zatreezabbix-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);
    }