设为首页 收藏本站
查看: 1178|回复: 0

[经验分享] 自定义监控(阿里云&zabbix)

[复制链接]

尚未签到

发表于 2019-1-25 06:03:28 | 显示全部楼层 |阅读模式
自定义监控(阿里云&zabbix)

  

目前阿里云对25端口有限制,无法在阿里云上搭建邮件服务器发送告警邮件,如果需要邮件通知,可以采取下面方法:
1.开同阿里云企业邮箱
2.使用阿里云监控告警
3.第三方zabbix自定义脚本监控
  一、阿里云自定义监控
阿里云提供自定义监控SDK,这有助于我们定制化的根据自身业务来做监控,下面我就根据业务需求来介绍一个简单的自定义监控配置。
  阿里提供了2个版本的自定义监控接口:
  自定义监控SDK(python版) :cms_post.py
  自定义监控SDK(bash版) :cms_post.sh
  下载地址: http://help.aliyun.com/knowledge_detail.htm?knowledgeId=5974901
  使用shell版本做演示
  监控mysql主从状态:
  1.创建自定义监控项


  脚本post方法说明
  1.命名空间中的字符串,用户aliuid
  2.监控项名称,用户创建监控项时填写的名称
  3.监控项值,用户上报到云监控的业务数据
  4.字段信息,结合监控项,表示具体业务字段意义。
mysql主从监控脚本
cat mysql_check.sh
#!/bin/bash
export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
export HOSTS=$(hostname)
mysql_user='root'
mysql_pass='123.com'
mail="xuel@51idc.com"
data=$(date +%Y-%m-%d-%H:%M)
netstat -lntup|egrep ":3306"|grep -v grep>/dev/null0
if [ $? -eq 0 ];then
Slave_IO=`mysql -u${mysql_user} -p${mysql_pass} -e "show slave status\G"|grep "Slave_IO_Running:"|awk -F": " '{print $2}'`
Slave_SQL=`mysql -u${mysql_user} -p${mysql_pass} -e "show slave status\G"|grep "Slave_SQL_Running:"|awk -F": " '{print $2}'`
if [ "$Slave_IO" == "Yes" ] && [ "$Slave_SQL" == "Yes" ];then
STAT=1 && echo "$data mysql-status is ok">>/var/log/mysql-status.log
else
STAT=0 && echo "$data mysql-status is error">>/var/log/mysql-status.log
fi
else
STAT=0 && echo "$data mysql-status is error">>/var/log/mysql-status.log
fi
/scripts/cms_post.sh 1931875513165389 mysql_status $STAT status=$HOSTS
制作定时任务,没分钟调用check脚本来上数据

cms_post.sh 阿里云上报脚本
#!/bin/bash
#########################################
#Usage:       sh cms_post.sh
#Author:      CMS Dev Team
#Company:     Aliyun Inc.
#Version:     1.0
#########################################
#parameters instructions
# $1: ali_uid, $2: metric_name, $3: metric_value, $4:fields
#convert current time to milliseconds
if [[ ! "$#" -eq 4 ]];then
echo "usage: $0 userId, metricName, value, dimensions"
echo "--multiple dimensions like 'ip=111.111.111.111,hostname=cms'"
exit 1
fi
#biz time
timestamp=`date +%s%N | cut -b1-13`
#build dimensions json
arr=(${4//,/ })
dimensions="{"
for i in "${arr[@]}"; do
kv=(${i//=/ })
    dimensions=${dimensions}'"'${kv[0]}'":"'${kv[1]}'",'
done
dimensions=${dimensions%,*}
dimensions=${dimensions}'}'
#build namespace and metrics
userId="$1"
namespace="acs/custom/$1"
metrics='[{"metricName":"'"$2"'","value":'"$3"',"unit":"None","timestamp":'"$timestamp"',"dimensions":'"$dimensions"'}]'
url="http://openNaNs.aliyun.com/metrics/put"
params="userId=$userId&namespace=$namespace&metrics=$metrics"
echo "params: ${params}"
curl -v ${url} --data ${params}添加完成监控后,监控图表如下:


告警配置


Status填写变量HOSTNAME 统计周期填写告警触发间隔

二、Zabbix监控方式
在被监控服务器上需要先安装zabbix-sender 来给zabbix-server提交发送数据
rpm -ivh http://repo.zabbix.com/zabbix/3.0/rhel/6/x86_64/zabbix-release-3.0-1.el6.noarch.rpm
yum install zabbix-sender -y#!/bin/bash
mysql_user='root'
mysql_pass='123.com'
mail="xuel@51idc.com"
data=$(date +%Y-%m-%d-%H:%M)
netstat -lntup|egrep ":3306"|grep -v grep>/dev/null0
if [ $? -eq 0 ];then
Slave_IO=`mysql -u${mysql_user} -p${mysql_pass} -e "show slave status\G"|grep "Slave_IO_Running:"|awk -F": " '{print $2}'`
Slave_SQL=`mysql -u${mysql_user} -p${mysql_pass} -e "show slave status\G"|grep "Slave_SQL_Running:"|awk -F": " '{print $2}'`
if [ "$Slave_IO" == "Yes" ] && [ "$Slave_SQL" == "Yes" ];then
STAT=1 && echo "$data mysql-status is ok">>/var/log/mysql-status.log
else
STAT=0 && echo "$data mysql-status is error">>/var/log/mysql-status.log
fi
else
STAT=0 && echo "$data mysql-status is error">>/var/log/mysql-status.log
fi
zabbix_sender -z 192.168.1.234 -s "test-mysql-status" -k mysql -o $STAT-z zabbix-server的地址
-s 监控项目名称
-k  键值
监控项目

触发器

监控图表





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-667126-1-1.html 上篇帖子: zabbix监控日志文件 MySQL日志为例 下篇帖子: zabbix 清理旧数据
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表