Zabbix的架构配置选项(二)

[toc]

Zabbix的架构配置选项(二)

一、添加自定义监控项目

Zabbix的特色:我们有时候会根据业务需求配置一些个性化的需求服务去监控某台web的80端口连接数,
并整出监控状态图:

  • [ ] zabbix监控中心创建监控项目;
  • [ ] 针对该监控项目以图形展现;

1.1 需要到客户端定义脚本:

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

#!/bin/bash
##获取80端口并发连接数
netstat -ant |grep ‘:80 ‘ |grep -c ESTABLISHED

1.2 给脚本授权,编辑配置文件

自定义监控项的key为my.estab.count(也就是在监控项中需要填写的键值),后面的[*]里面写脚本的参数

# 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

1.3 重启客户端的zabbix服务:

[[email protected] ~]# systemctl restart zabbix-agent

1.4 到服务端验证,执行命令:

[[email protected] ~]# zabbix_get -s 192.168.72.133 -p 10050 -k ‘my.estab.count‘
0

-s:源地址
-p: 端口
-k: 键值

如上显示0即为没有任何连接。

1.5 但是这不是我们需要的效果,效果是我们需要在web页面去随时查看:

配置 → 主机 → 监控项 → 创建监控项

  • 其它项默认即可,如有需求按照现场需求定制。

1.6 配置一个监控图形:

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

1.7 创建触发器

二、配置邮件告警

配置告警是目前绝大多数企业必须要有的一个状态,遇到问题第一时间获得警告大大提升了运维的高效性,如果没有配置任何告警,等待客户反应,这是一个非常不明智的选择。

2.1 在开始前,一定要把这两项开启:

2.2 将授权码开通并定义

2.3 编辑报警媒介

登录web管理界面:

管理 → 报警媒介类型 → 创建媒体类型(不建议用自带的,不好用)

脚本名称一定要用自己自定义的!!!

脚本参数(不然不可以发邮件):

{ALERT.SENDTO} //发给谁

{ALERT.SUBJECT} //主题

{ALERT.MESSAGE} //邮件内容

2.4 写一个报警的邮件脚本:

在服务端配置:

[[email protected] ~]# vim /usr/lib/zabbix/alertscripts/Sendmail.py

脚本为什么放在这边呢?因为咱们在配置文件中=vim /etc/zabbix/zabbix_server.conf有个参数 AlertScriptsPath=/usr/lib/zabbix/alertscripts 定义了位置

vim Sendmail.py

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.163.com‘  #编写服务地址
    gport = 25
    try:
        msg = MIMEText(unicode(content).encode(‘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]
##定义邮箱的账号和密码,你需要修改成你自己的账号和密码(请不要把真实的用户名和密码放到网上公开,否则你会死的很惨)
    sendqqmail(‘[email protected]‘,‘Password‘,‘[email protected]‘,to,subject,content)
    //注意这里的password是刚才在163邮箱设置的授权码

赋权限,测试邮件运行结果

[[email protected] alertscripts]# chmod 755 /usr/lib/zabbix/alertscripts/Sendmail.py
[[email protected] alertscripts]# python Sendmail.py [email protected] ‘torreicdmailcn‘ ‘datatime20180417‘   

2.5 创建运维人员的邮箱,接受报警邮件

管理 -> 用户 -> 创建用户

创建一个接受告警邮件的用户,“管理”,“用户”,“创建用户”,“报警媒介”,类型选择“baojing”,注意用户的权限,如果没有需要到用户组去设置权限

给创建的用户,赋予权限

关于权限选项,我们先保存当前的配置,然后进入用户群组 → Zabbix administrators → 权限

为了防止发生错误,暂时先选择全部用户。千万不要忘记点击添加

授权成功后更新,检查下用户权限

2.6 权限设定成功,下一步设定报警动作

“配置”,“动作”,“创建动作”,

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

增加一个触发动作

  • 新的触发条件”,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}

对恢复操作部分修改

“恢复操作”,把信息改成如下:

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”

点击添加后查看

三、验证配置:

配置 → 主机 → 触发器 → 创建触发器

条件是,并发数小于1,咱们的虚拟机压根就没有任何人去访问,所以必然报警。

在邮箱里查收

修改参数,查看恢复邮件

原文地址:http://blog.51cto.com/12995218/2104606

时间: 2024-10-13 16:00:10

Zabbix的架构配置选项(二)的相关文章

Zabbix的架构配置选项

[toc] Zabbix的架构配置选项 一.zaabix的主动模式和被动模式 首先确定一点是,主动模式和被动模式针对的是客户端. [ ] 被动模式,服务端会主动连接客户端获取监控项目数据,客户端被动地接受连接,并把监控信息传递给服务端 [ ] 主动模式,客户端会主动把监控数据汇报给服务端,服务端只负责接收即可. [ ] 什么时候用主动模式或者被动模式呢? 1.当客户端数量非常多时,建议使用主动模式,这样可以降低服务端的压力. 2.服务端有公网ip,客户端只有内网ip,但却能连外网,这种场景适合主

Zabbix监控介绍&配置zabbix架构

[toc]# Linux监控平台介绍 常见的有 cacti.nagios.zabbix.smokeping.open-falcon等等. cacti.smokeping偏向于基础监控,成图非常漂亮. cacti.nagios.zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,这几款监控软件均有web操作界面. nagios不用存储历史数据,注重服务或者监控项的状态. zabbix优势: zabbix会获取服务或者监控项目的数据,会把数据记录

zabbix基础配置(二)

zabbix基础配置(二) ============================================================================= 概述: ============================================================================= zabbix agent安装配置:  安装配置过程 1.安装 # yum install zabbix-agent-3.0.2-1.el7.x86_64

Ansible-playbook批量添加zabbix监控项目、同步配置信息(二)

前言 在上一篇教程中我们已经实现了使用ansible-playbook批量在远程主机上部署zabbix客户端并正常运行,现在我们再次通过ansible-playbook给客户端主机批量增加zabbix监控项目配置(创建监控项目示例:自动发现远程主机监听的TCP端口.监控远程主机的TCP连接数状态). Ansible-playbook 配置 在原有的基础目录上创建一个configure角色以及ansible的各个模块任务目录列表,通过ansible-playbook调用入口文件zabbix_con

linux 下zabbix 监控简单配置

一.搭建环境介绍 hostname IP zabbix版本 系统版本 服务端 webserver 192.168.1.20 zabbix2.2 CentOS 6.6 客户端 hpf-linux 192.168.1.110 zabbix2.2 CentOS 6.6 二.zabbix的常用配置 1.更改浏览器下zabbix的显示语言 由于默认的浏览器下zabbix是英文,我们可以更改zabbix为中文:点击右上角的profile-->在language栏选择中文-->点击save保存: 查看zab

Linux 系统裁剪笔记 4 (内核配置选项及删改)

在menuconfig中配置,可以对进行Linux内核配置选项及删改.本文介绍详细配置方法.第一部分:全部删除Code maturity level options ---> 代码成熟等级选项[]Prompt for development and/or incomplete code/drivers 默认情况下是选择的,这将会在设置界面中显示还在开发或者还没有完成的代码与驱动.不选.第二部分 :除以下选项,其它全部删除General setup-〉System V IPC (IPC:Inter

zabbix监控架构原理

一.zabbix介绍 zabbix是一款企业级的监控软件,可以监控的底层硬件包括主机,cpu,内存,交换机等信息,同时也可以基于软件层面做监控,包括进程,端口,文件等状态变化. 二.zabbix监控架构及流程图1.架构图 zabbix常见的监控方式agent,snmp,IPMAzabbix采用server/client架构和server-proxy-client架构两种方式当node节点比较多时采用server-proxy-client这种方式,避免server压力太大,起到分流作用 各组件如何

Zabbix&LAMP安装配置

监控端操作 基于LAMP架构部署Zabbix #!/bin/bash #基于LAMP架构安装Zabbix # lamp(){ #关闭防火墙&核心安全功能systemctl stop firewalld.servicesystemctl disable firewalld.service &> /dev/nullsetenforce 0sed -i "7cSELINUX=disabled" /etc/sysconfig/selinux #下载安装必要组件yum in

Zabbix&LNMP安装配置

监控端操作 #!/bin/bash #安装zabbix+LNMP # lnmp(){ #关闭防火墙&核心安全功能 systemctl stop firewalld.service systemctl disable firewalld.service &> /dev/null setenforce 0 sed -i "7cSELINUX=disabled" /etc/sysconfig/selinux #yum安装nginx wget http://nginx.o