linux监控平台搭建(四)

原文链接: https://my.oschina.net/u/3959687/blog/2993816

=

12月26日

19.12 添加自定义监控项目

添加自定义监控项目

· 需求:监控某台web的80端口连接数,并出图

· 两步:1)zabbix监控中心创建监控项目;2)针对该监控项目以图形展现

· 对于第一步,需要到客户端定义脚本

· vim /usr/local/sbin/estab.sh //内容如下

#!/bin/bash

##获取80端口并发连接数

netstat -ant |grep ':80 ' |grep -c ESTABLISHED  

· chmod 755 /usr/local/sbin/estab.sh  设置执行权限

·客户端上编辑配置文件 vim /etc/zabbix/zabbix_agentd.conf//增加

UnsafeUserParameters=1  //表示使用自定义脚本

UserParameter=my.estab.count[*],/usr/local/sbin/estab.sh 

//自定义监控项的key为my.estab.count,后面的[*]里面写脚本的参数,如果没有参数则可以省略,脚本为/usr/local/sbin/estab.sh

· systemctl restart zabbix-agent重启zabbix-agent服务 

· 首先到服务端验证,执行命令 (结果显示0为正常)

· zabbix_get -s 192.168.133.132 -p 10050 -k 'my.estab.count

· 然后在zabbix监控中心(浏览器)配置增加监控项目

 键值写my.estab.count(主机——监控项——创建监控项)

· 添加该项目后,到“监测中”à “最新数据”查看刚添加的项目是否有数据出现

· 有了数据就可以添加图形了

 “配置”à“主机” à“图形” à“创建图形”

· 触发器——创建触发器(功能最新的t值>200 N=200)

 

19.13/19.14 配置邮件告警

配置告警(服务端)

· 使用163或者QQ邮箱发告警邮件 

· 首先登录你的163邮箱,设置开启POP3、IMAP、SMTP服务,

·  开启并记录授权码

·  然后到监控中心设置邮件告警

· “管理”,“报警媒介类型”,“创建媒体类型”

·  {ALERT.SENDTO} 接收邮箱地址,

    {ALERT.SUBJECT}主题,

    {ALERT.MESSAGE}邮件内容

linux监控平台搭建(四)_第1张图片

 

 

· 创建报警脚本mail.py

    Vi /etc/zabbix、zabbix_server.conf 查看alertscriptspath指定的脚本目录

·vim /usr/lib/zabbix/alertscripts/mail.py内容参考https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D22Z/mail.py

#!/usr/bin/env python

#-*- coding: UTF-8 -*-

import os,sys

reload(sys)

sys.setdefaultencoding('utf8')

import getopt

import smtplib

from email.MIMEText import MIMEText

from email.MIMEMultipart import MIMEMultipart

from  subprocess import *

 

def sendqqmail(username,password,mailfrom,mailto,subject,content):

    gserver = 'smtp.qq.com'   或 = smtp.163.com

    gport = 25

 

    try:

        # msg = MIMEText(unicode(content).encode('utf-8')) //如果发送的邮件有乱码,可以尝试把这行改成如下:

        msg = MIMEText(content,'plan','utf-8') 

        msg['from'] = mailfrom

        msg['to'] = mailto

        msg['Reply-To'] = mailfrom

        msg['Subject'] = subject

 

        smtp = smtplib.SMTP(gserver, gport)

        smtp.set_debuglevel(0)

        smtp.ehlo()

        smtp.login(username,password)

 

        smtp.sendmail(mailfrom, mailto, msg.as_string())

        smtp.close()

    except Exception,err:

        print "Send mail failed. Error: %s" % err

 

 

def main():

    to=sys.argv[1]

    subject=sys.argv[2]

    content=sys.argv[3]

##定义QQ邮箱的账号和密码,你需要修改成你自己的账号和密码(请不要把真实的用户名和密码放到网上公开,否则你会死的很惨)

    sendqqmail('[email protected]','aaaaaaaaaa','[email protected]',to,subject,content)

 

if __name__ == "__main__":

    main()

    

    

#####脚本使用说明######

#1. 首先定义好脚本中的邮箱账号和密码

#2. 脚本执行命令为:python mail.py 目标邮箱 "邮件主题" "邮件内容"

 

·  chmod 755 /usr/lib/zabbix/alertscripts/mail.py  设置权限

   python mail.py [email protected] sdnjhfyub  测试是否发邮件

· 创建一个接受告警邮件的用户,“管理”,“用户”,“创建用户”,“报警媒介”,类型选择“baojing”,收件人“邮箱地址”,用户群组—权限—读写—选择所有组。最后添加。注意用户的权限,如果没有需要到用户组去设置权限

 · 设置动作,“配置”,“动作”,“创建动作”,名称写“sendmail”(自定义),“操作”页面,内容如下

HOST:{HOST.NAME} {HOST.IP}

TIME:{EVENT.DATE}  {EVENT.TIME} 

LEVEL:{TRIGGER.SEVERITY} 

NAME:{TRIGGER.NAME}

messages:{ITEM.NAME}:{ITEM.VALUE}

ID:{EVENT.ID}

发送到用户 aming

· 动作——“新的触发条件”,A维护状态 非在 维护,添加 —B触发器示警度>=未分类

 

“操作”,选择发送的用户为刚创建的用户,仅送到选择“baojing”,事件已确认=非确认

 

 切换到“恢复操作”,把信息改成如下

HOST:{HOST.NAME} {HOST.IP}

TIME:{EVENT.DATE}  {EVENT.TIME} 

LEVEL:{TRIGGER.SEVERITY} 

NAME:{TRIGGER.NAME}

messages:{ITEM.NAME}:{ITEM.VALUE}

ID:{EVENT.ID}

 点击“新的”,“操作”,选择发送的用户为刚创建的用户,仅送到选择“baojing”

 测试告警

 

19.15 测试告警

· 创建个自定义触发器

系统负载—警告—添加表达式(processor load)—最新的t值<1 N=1) —添加

出现问题可以从头到尾检查。

·  python mail.py [email protected] sdnjhfyub 测试脚本

·  ls -l mail.py查看脚本权限(改成777)

·  管理—用户—aming—报警媒介—权限,读写

·  动作—操作—默认信息还原—发送到用户—更新

· 主机—触发器-系统负载—表达式>1  (恢复)

19.16 不发邮件的问题处理

1, 到163邮箱,设置开启POP3、IMAP、SMTP服务,开启授权码

2. 然后到监控中心设置邮件告警

  新增报警媒介—报警—类型脚本—脚本参数

  1.  vim /etc/lib/zabbix/alertscripts/aming.py  到指定路径创建个脚本 ,还有更改脚本权限。、
  2.  管理—用户群组—权限改成读写
  3.   管理—用户—权限改成读写—报警媒介加邮箱地址
  4.  配置—动作—条件保持默认

   配置—动作—操作—默认信息更改—添加用户—仅送到报警

  配置—动作—恢复操作—默认信息更改—发送aming用户—仅送到报警

配置—主机—触发器—增加system.cpu.load  <1 (手动增加个报警信息

 

 systemctl stop zabbix-agent  也可以在客户端把进程停止 、

主动和被动

配置—主机—监控项—agent ping—类型 zabbix客户端(被动) zabbix客户端(主动式)/主动上报

 

 

 

转载于:https://my.oschina.net/u/3959687/blog/2993816

你可能感兴趣的:(linux监控平台搭建(四))