mysqlshell日常运维脚本(监控MySQL主从状态的shell脚本)
类别:数据库 浏览量:2132
时间:2022-01-15 01:41:10 mysqlshell日常运维脚本
监控MySQL主从状态的shell脚本分享一个Linux下,监控MySQL主从状态及配合企业微信机器人报警的Shell脚本
- SLAVE_IP:为监控的主机IP
- USER:为msyql用户
- PASSWORD:为mysql密码
- WHEREIS_MYSQL:为mysql命令路径
- WEBHOOK:为企业微信机器人Webhook地址
- wx():为企业微信机器人函数
- Check_Mysql_Slave():为监控脚本主函数
|
#! /bin/bash # source /etc/profile export PATH= "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" SLAVE_IP=`ip add | grep inet | grep brd | awk -F / '{print $1}' | awk -F " " '{print $2}' | awk 'NR==1' ` USER=monitor PASSWORD=xxxxxx TIME=` date ` WHEREIS_MYSQL= /opt/mysql/bin/mysql WEBHOOK= 'https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=bb09197b-5ff6-4928-9872-xxxxxx' wx(){ cat > $0.msg << EOF curl '$WEBHOOK' \ -H 'Content-Type: application/json' \ -d ' { "msgtype" : "text" , "text" : { "content" : "$1" , } }' EOF sh $0.msg && rm -rf $0.msg } Check_Mysql_Slave() { $WHEREIS_MYSQL -u$USER -p$PASSWORD -h$SLAVE_IP -e "select version();" > /dev/null 2>&1 if [ $? - ne 0 ]; then echo "Mysql is stopped $DATE" >> /data/mysql/check .log ERROR= "ERROR:Mysql-$SLAVE_IP cannot connect\n$TIME" wx "$ERROR" else #echo "1" >> /data/mysql/check.log IO_SQL_STATUS=`$WHEREIS_MYSQL -u$USER -p$PASSWORD -h$SLAVE_IP -e "show slave status \G" 2> /dev/null | awk '/Slave_.*_Running:/{print $1$2}' ` for i in $IO_SQL_STATUS; do THREAD_STATUS_NAME=${i%:*} THREAD_STATUS=${i #*:} if [ "$THREAD_STATUS" != "Yes" ]; then STATUS= "ERROR:Mysql-$SLAVE_IP $THREAD_STATUS_NAME status is $THREAD_STATUS!\n$TIME" echo "$STATUS" >> /data/mysql/check .log wx "$STATUS" fi done fi } Check_Mysql_Slave |
最终报警效果如下:
以上就是监控MySQL主从状态的shell脚本的详细内容,更多关于监控MySQL主从状态的资料请关注开心学习网其它相关文章!
原文链接:https://www.cnblogs.com/easydb/p/14135276.html
您可能感兴趣
- mysql发生系统错误(MySQL too many connections错误的原因及解决)
- mysql首次登录不上怎么办(Mysql匿名登录无法创建数据库问题解决方案)
- mysql密码找回方法(MySQL8忘记密码的快速解决方法)
- pythonmysql使用教程(Python异步操作MySQL示例使用aiomysql)
- mysql如何使用临时表(MySQL中临时表的使用示例)
- mysql中默认排序教程(基于mysql 默认排序规则的坑)
- 最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)(最新版MySQL 8.0.22下载安装超详细教程Windows 64位)
- mysql binlog模式实际使用(实例验证MySQL|update字段为相同的值是否会记录binlog)
- MySQL 使用事件(Events)完成计划任务(MySQL 使用事件Events完成计划任务)
- mysql怎么创建联合索引(mysql的联合索引复合索引的实现)
- mysql索引提高效率(MySql如何查看索引并实现优化)
- phpstudy怎么升级mysql(phpStudy中升级MySQL版本到5.7.17的方法步骤)
- mpp数据库的客户端工具(xampp默认mysql数据库root密码的修改)
- mysql和mycat半主从复制项目(Linux如何使用 MyCat 实现 MySQL 主从读写分离)
- mysql自增长语句(mysql实现自增序列的示例代码)
- mysql 8.0.22 winx64安装配置方法图文教程(mysql 8.0.22 winx64安装配置方法图文教程)
- 庆余年剧组重聚王牌5,宋轶神秘消失,肖战出现一秒抢了李纯风头(庆余年剧组重聚王牌5)
- 巴厘岛旅游攻略(巴厘岛旅游攻略7天多少钱)
- 文莱旅游攻略(文莱旅游攻略介绍)
- 马来西亚旅游攻略(马来西亚旅游攻略自由行攻略)
- 缅甸旅游攻略(缅甸旅游攻略必去景点推荐)
- 《庆余年2》新消息,原班人马,肖战特别出演,这才是最好的安排(庆余年2新消息原班人马)
热门推荐
- mysql怎么和sqlyog连接(Mysql桌面工具之SQLyog资源及激活使用方法告别黑白命令行)
- dockercompose设置系统环境变量(使用docker compose搭建consul集群环境的例子)
- sql server设置自增(sql server建表时设置ID字段自增的简单方法)
- 微信开发接口文档地址
- python将字符串转换为时间格式(Python时间和字符串转换操作实例分析)
- html5canvas怎么改扇形起始角(HTML5 Canvas实现放大镜效果示例)
- dedecms中如何设置推荐文章(实现dedecms友情链接分栏目调用的方法图)
- webapp隐藏地址栏
- iframe跨域原理(详解使用postMessage解决iframe跨域通信问题)
- nginx反向代码解决跨域访问(nginx 解决跨域问题嵌入第三方页面)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9