自定义监控(阿里云&zabbix)

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介:

自定义监控(阿里云&zabbix)


目前阿里云对25端口有限制,无法在阿里云上搭建邮件服务器发送告警邮件,如果需要邮件通知,可以采取下面方法:

1.开同阿里云企业邮箱

2.使用阿里云监控告警

3.第三方zabbix自定义脚本监控

一、阿里云自定义监控

阿里云提供自定义监控SDK,这有助于我们定制化的根据自身业务来做监控,下面我就根据业务需求来介绍一个简单的自定义监控配置。

阿里提供了2个版本的自定义监控接口:

自定义监控SDKpython版) :cms_post.py

自定义监控SDKbash版) :cms_post.sh

下载地址: http://help.aliyun.com/knowledge_detail.htm?knowledgeId=5974901 

使用shell版本做演示

监控mysql主从状态:

1.创建自定义监控项

wKiom1kQai2Qv3owAACb2f3usAY723.png

wKioL1kQameBdgK3AABn-K1lGqs176.png

脚本post方法说明

1.命名空间中的字符串,用户aliuid

2.监控项名称,用户创建监控项时填写的名称

3.监控项值,用户上报到云监控的业务数据

4.字段信息,结合监控项,表示具体业务字段意义。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
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脚本来上数据

wKiom1kQaszxhVqvAAA6xQXj1_Y361.png

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
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  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}


添加完成监控后,监控图表如下:

wKiom1kQazCzCXQkAADajb6HN34335.png

告警配置

wKioL1kQa12yG09XAABD27Y1XHI796.png


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

wKioL1kQa5Xj3EYAAAB5x5fQGQc077.png



二、Zabbix监控方式

在被监控服务器上需要先安装zabbix-sender 来给zabbix-server提交发送数据

1
2
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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#!/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  键值

监控项目

wKioL1kQbF3yDxjBAAEljV-N_S4809.png

触发器

wKioL1kQbJ_C7rQzAACzS16rmXM545.png

监控图表

wKiom1kQbN6w2xTwAAKaDZfTseo876.png










本文转自 KaliArch 51CTO博客,原文链接:http://blog.51cto.com/kaliarch/1923429,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
5月前
|
监控 应用服务中间件 nginx
基于Zabbix的SLA监控体系构建与实践
本文由Zabbix社区专家褚凤彬分享,详解SLA在Zabbix中的应用。通过Trigger与Service联动,构建Web应用的多层级监控体系,并介绍SLA计算规则、维护期处理及升级注意事项,助力企业精准掌控服务可用性。
511 36
|
11月前
|
运维 监控 安全
【案例分享】中国通号卡斯柯公司:ZABBIX如何破解轨道交通监控难题
本文根据2023上海峰会上朱林贤的演讲整理,聚焦中国通号卡斯柯公司如何借助Zabbix实现轨道交通信号系统的智能化管理。作为中外合资企业,卡斯柯通过统一平台整合设备监控,大幅降低成本并提升灵活性,成功应用于国内外项目。文章探讨了传统监控系统的痛点、研发维护经验及国产化与开源技术挑战,为行业转型提供了宝贵启示。未来,开放协作将是推动轨道交通智能化发展的关键。
548 8
|
存储 缓存 监控
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
198 23
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
330 25
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
383 22
|
监控 安全 前端开发
使用 Zabbix 监控堆外应用
使用 Zabbix 监控堆外应用
263 9
|
监控 数据可视化 Java
zabbix全面的监控能力
zabbix全面的监控能力
540 7
|
监控 Java Shell
监控堆外第三方监控工具Zabbix
监控堆外第三方监控工具Zabbix
377 5
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
495 7