zabbix怎样监控windows邮件服务器
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了zabbix怎样监控windows邮件服务器相关的知识,希望对你有一定的参考价值。
参考技术A 您好,是这样的:zabbix基本架构:1.Serverzabbix系统核心进程,轮询并捕获数据、发送通知等。是zabbixagent和zabbixproxy汇报数据的对象。server自身可远程检测网络服务。所有的前后端配置、统计信息、可操作数据存储于此。包含server、前段界面和后端DB几部分。2.Agent部署在被监控主机上用于监控本地资源和应用并向zabbixserver汇报结果。使用本地系统调用故非常高效。有主动和被动两种检测模式。被动模式下agent根据server或proxy的具体请求来返回数据。主动模式下先主动由server获取监控项列表在检测并返回新的数据。采用主动或被动检测取决于相应监控项的配置。3.Proxy可以自由选择部署或者不部署,主要用于分担server的负载。在集中化监控远程位置、分支、网络的场景中是很好的解决方案。可从被监控设备收集数据缓存在proxy本地后传递给其所属的zabbixserver。proxy需要单独的数据库。4.Javagatewayjava实现的守护进程用于监控JMX类型的应用程序。5.Sender命令行工具zabbix_sender,用于向zabbixserver发送性能数据和可用性数据。多用于用户脚本定期向server发送数据。 参考技术B 仅在里边定义连接字串,在使用的时候在创建对象,使用完对象就关闭Config.asp:Quote <%Dim Def_SampleDef_Path=server.MapPath("data.mdb")Def_Sample="DBQ="+Def_Path+";DefaultDir=;DRIVER=Microsoft Access Driver (*.mdb);" '连接字串%>zabbix实现邮件报警
说明:
zabbix服务端配置文件主要参数
LogFile=/tmp/zabbix_server.log
DBName=zabbix #zabbix的密码
DBUser=root #用来连接mysql的用户名
DBPassword= #密码
DBHost=127.0.0.1 #本机
DBSocket=/data/mysql_3306/var/mysql_3306.sock #mysql的sock端口
ListenIP=127.0.0.1
date.timezone = "Asia/Shanghai"
Zabbix监控服务端、客户端都已经部署完成,被监控主机已经添加,Zabiix监控运行正常。
实现目的:
在Zabbix服务端设置邮件报警,当被监控主机宕机或者达到触发器预设值时,会自动发送报警邮件到指定邮箱。
具体操作:
以下操作在Zabbix监控服务端进行
备注:Zabbix监控服务端
操作系统:CentOS
使用外部邮箱账号发送报警邮件设置:
一、关闭sendmail或者postfix
service sendmail stop #关闭
chkconfig sendmail off #禁止开机启动
service postfix stop
chkconfig postfix off
备注:
使用外部邮箱账号时,不需要启动sendmail或者postfix
如果在sendmail或者postfix启动的同时使用外部邮箱发送报警邮件,首先会读取外部邮箱
配置信息。
二、安装邮件发送工具mailx
yum install mailx #安装
CentOS 5.x 编译安装mailx,直接yum安装的mailx版本太旧,使用外部邮件发送会有问题。
yum remove mailx #卸载系统自带的旧版mailx
下载mailx:
http://nchc.dl.sourceforge.net/project/heirloom/heirloom-mailx/12.4/mailx-12.4.tar.bz2
tar jxvf mailx-12.4.tar.bz2 #解压
cd mailx-12.4 #进入目录
make #编译
原来差补丁,修复他
[root@localhost mailx-12.4]
# wget http://www.linuxfromscratch.org/patches/blfs/7.6/mailx-12.4-openssl_1.0.0_build_fix-1.patch
[root@localhost mailx-12.4]
# patch -Np1 -i mailx-12.4-openssl_1.0.0_build_fix-1.patch
patching
file
makeconfig
patching
file
openssl.c
[root@localhost mailx-12.4]
# make clean #清除历史编译后文件
make install UCBINSTALL=/usr/bin/install #安装
ln -s /usr/local/bin/mailx /bin/mail #创建mailx到mail的软连接
ln -s /etc/nail.rc /etc/mail.rc #创建mailx配置文件软连接
三、配置Zabbix服务端外部邮箱
vi /etc/mail.rc #编辑,添加以下信息
set from=xxx@163.com
set smtp=smtp.163.com //添加发送人、发送服务器
set smtp-auth-user=xxx@163.com
set smtp-auth-password=123456 //添加发送人的邮箱和登录密码。
set smtp-auth=login
:wq! #保存退出
echo "zabbix test mail" |mail -s "zabbix" yyy@163.com
#测试发送邮件,标题zabbix,邮件内容:zabbix test mail,发送到的邮箱:yyy@163.com或者zzz@139.com,发送短信的时候要在139邮箱上面开启短信提醒。这里我就不说了,自己百度去。
#这时候,邮箱yyy@163.com会收到来自xxx@163.com的测试邮件
四、配置Zabbix服务端邮件报警
1、打开Zabbix
管理-示警媒介类型-创建媒体类型
名称:Sendmail
类型:脚本
脚本名称:sendmail.sh
已启用:勾选
2、设置Zabbix用户报警邮箱地址
可以添加163邮箱也可以添加139邮箱。
类型:Sendmail
收件人:xxx@163.com
其他默认即可,也可
以根据需要设置
状态:已启用
存档
3、设置Zabbix触发报警的动作
组态-动作-创建动作
名称:Action-Email
默认接收人:故障{TRIGGER.STATUS},服务器:{HOSTNAME1}发生: {TRIGGER.NAME}故障!
默认信息:
告警主机:{HOSTNAME1}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警项目:{TRIGGER.KEY1}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID:{EVENT.ID}
恢复信息:打钩
恢复主旨:恢复{TRIGGER.STATUS}, 服务器:{HOSTNAME1}: {TRIGGER.NAME}已恢复!
恢复信息:
告警主机:{HOSTNAME1}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警项目:{TRIGGER.KEY1}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID:{EVENT.ID}
已启用:打钩
切换到操作选项
新的
操作类型:送出信息
送到用户:添加
默认信息:打钩
选择用户:Admin
选择
仅送到:Sendmail
存档
4、添加Zabbix服务端邮件发送脚本
cd /usr/local/zabbix/share/zabbix/alertscripts #进入脚本存放目录
vi sendmail.sh #编辑,添加以下代码
#!/bin/sh
echo "$3" | mail -s "$2" $1
:wq! #保存退出
chown -R zabbix.zabbix /usr/local/zabbix/share/zabbix/alertscripts/*
zabbix_server.conf 文件中加入脚本的相对路径
AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts
#设置脚本所有者为zabbix用户
chmod +x /usr/local/zabbix/share/zabbix/alertscripts/sendmail.sh
#设置脚本执行权限
五、测试Zabbix报警
关闭Zabbix客户端服务
service zabbix_agentd stop
查看你的xxx@163.com邮箱,会收到报警邮件
再开启Zabbix客户端服务
service zabbix_agentd start
查看你的xxx@163.com邮箱,会收到恢复邮件
使用外部邮箱账号发送报警邮件设置完成。
至此,Zabbix邮件报警设置完成。
阿里云不让自建邮箱,是为了防止邮件乱发,又不发溯源
所有25端口全部被封
改用465端口
我选得163邮箱,建一个设置个复杂密码一辈子不登陆了
上去设置里开启 SMTP pop 什么的都点开
网上搜了搜,没发现能成功测试的,都有一点报错
下面我的版本,贴出来,大家用吧
遇到的报错:"/root/dead.letter" 311/19508
553 Mail from must equal authorized user
反正挺恶心,2天才搞定
然后安装mailx
yum install mailx
vi /etc/mail.rc
添加下面这些
set smtp="smtps://smtp.163.com:465"
set from="1111111111@163.com"
set smtp-auth=login
set smtp-auth-user="11111111@163.com"
set smtp-auth-password="111111111"
set ssl-verify=ignore
set nss-config-dir=/etc/pki/nssdb
测试
cat /opt/1111 | mailx -v -s \'biaoti\' \'1111111111111@qq.com\'
以上是关于zabbix怎样监控windows邮件服务器的主要内容,如果未能解决你的问题,请参考以下文章