监控mysql状态_监控mysql状态脚本
发布日期:2022-02-03 13:16:58 浏览次数:22 分类:技术文章

本文共 2416 字,大约阅读时间需要 8 分钟。

监控mysql状态, 发现宕后, 自动重启, 每秒检查一次。

check.sh

#!/bin/bash

while [ true ]; do

/bin/sleep 1

sh mysql_status.sh

done

chengkill

#!/bin/sh

#pid kill thread for chenglee

#if fileformat=dos, update fileformat=unix

#code:set fileformat=unix

#check:set ff ?

if [ $# -lt 1 ]

then

echo "not procedure_name"

exit 1

fi

PROCESS=`ps -ef|grep $1|grep -v grep|grep -v PPID|awk '{ print $2}'`

for i in $PROCESS

do

echo "Kill the $1 process [ $i ]"

kill -9 $i

done

chengkill授执行权扔/usr/bin

mysql_status.sh

#!/bin/bash

#/usr/bin/nmap localhost | grep 3306

#lsof -i:3306

MYSQLPORT=`netstat -tlnp | grep "3306"|awk -F[:" "]+ '{print $4}'`

STR_TIME=$ date "+%Y-%m-%d %H:%M:%S"

function checkMysqlStatus(){

/usr/bin/mysql -uroot -plizhenghua --connect_timeout=5 -e "show databases;" &>/dev/null 2>&1

if [ $? -ne 0 ]

then

restartMysqlService

if [ "$MYSQLPORT" == "3306" ];then

echo "mysql restart successful......"

else

echo "mysql restart failure......"

python mail.py

fi

else

echo "mysql is running..."

fi

}

function restartMysqlService(){

cat code.txt

echo "测试重启mysql服务!"

echo "清除mysql残余!"

chengkill mysqld

echo "准备重启!"

service mysqld restart

echo "重启成功!"

# python mail.py

}

if [ "$MYSQLPORT" == "3306" ]

then

checkMysqlStatus

else

restartMysqlService

fi

mail.py

#!/usr/bin/python

#-*- coding:utf-8 -*-

#Python Mail for chenglee

#if fileformat=dos, update fileformat=unix

#code:set fileformat=unix

#check:set ff ?

import smtplib

from email.mime.text import MIMEText

from email.utils import formataddr

my_sender='11318@qq.com' # 发件人邮箱账号

my_pass = 'mwbajizijah' # 发件人邮箱密码(当时申请smtp给的口令)

my_user='14783@qq.com' # 收件人邮箱账号,我这边发送给自己

my_content='系统管理员您好,该系统的mysql进程已经崩溃并重启失败,请手动重启!!'

my_title='进程告警'

def mail():

ret=True

try:

msg=MIMEText(my_content,'plain','utf-8')

msg['From']=formataddr(["发件人昵称",my_sender]) # 括号里的对应发件人邮箱昵称、发件人邮箱账号

msg['To']=formataddr(["收件人昵称",my_user]) # 括号里的对应收件人邮箱昵称、收件人邮箱账号

msg['Subject']=my_title # 邮件的主题,也可以说是标题

server=smtplib.SMTP_SSL("smtp.qq.com", 465) # 发件人邮箱中的SMTP服务器,端口是465

server.login(my_sender, my_pass) # 括号中对应的是发件人邮箱账号、邮箱密码

server.sendmail(my_sender,[my_user,],msg.as_string()) # 括号中对应的是发件人邮箱账号、收件人邮箱账号、发送邮件

server.quit()# 关闭连接

except Exception:# 如果 try 中的语句没有执行,则会执行下面的 ret=False

ret=False

return ret

ret=mail()

if ret:

print("邮件发送成功")

else:

print("邮件发送失败")

code.txt

/

/   /   /

____,____ /

// |ヽヽ \  /

^^^^^|^^^^^^^

/   | ∩,,∩ /  /

|(*(T)*)

/  0と  )  /

し─ J

chenglee

前后两个放在同一个目录, 中间chengkill扔bin, 然后守护模式运行check.sh。

转载地址:https://blog.csdn.net/weixin_34759094/article/details/113303447 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:mysql db模块下载_亲测:MySQL安装与python下的MySQLdb使用(附软件与模块包)
下一篇:qt 调用createfile打开串口_在Ubuntu中的串口通信(1)-串口设备读写权限问题

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2024年08月28日 03时13分46秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

AngularJS 简介及基础用法(双向数据绑定、依赖注入、模块对象、相关指令、动态练习) 2019-05-24
JS模块化 介绍(CommonJS、AMD-RequireJS、CMD-SeaJS、ES6_Babel_Browserify) 2019-05-24
Node.JS 介绍及基础知识(模块化简介、NPM用法、Buffer缓冲区、fs文件系统) 2019-05-24
①webpack 简介及开发环境配置 2019-05-24
②webpack 生产环境配置 2019-05-24
操作系统:Java模拟作业调度算法(先来先服务、短作业优先、高响应者优先) 2019-05-24
计算机视觉技术:C++和opencv插件 实现比较均值、中值、高斯滤波,对不同噪音(椒盐、高斯噪音)的抑制效果 2019-05-24
③webpack 优化环境配置 2019-05-24
④webpack 配置详解 2019-05-24
①Vue介绍及基本用法(模板语法、计算属性和监视、条件渲染、列表渲染、列表搜索和排序、事件处理、表单输入绑定、生命周期、动画、过滤器、指令) 2019-05-24
操作系统:Java模拟银行家算法 2019-05-24
②Vue 使用vue-cli创建模板项目、组件化编码流程简述 2019-05-24
③Vue vue-ajax、UI组件库、vue-router 2019-05-24
④Vuex基本用法 2019-05-24
前端面试题 HTML5 CSS3(盒子模型、盒子水平垂直居中、经典布局) JS(闭包、深浅克隆、数据劫持和拦截) 算法(排序、去重、数组扁平化) Vue(双向数据绑定原理、通信方式) 2019-05-24
操作系统:Java模拟内存管理(循环首次适应算法、回收空间算法) 2019-05-24
操作系统:Java模拟页面置换算法(最佳置换算法、先进先出算法、最近最久未使用算法) 2019-05-24
⑤mpvue 小程序框架 :初始化项目 分析项目结构 2019-05-24
⑥mpvue 很基础的小程序页面搭建(vuex管理状态、实现收藏和分享功能) 2019-05-24
⑦mpvue Flyio实现前后台交互 2019-05-24