欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 美食 > Mysql 设置 慢SQL时间并触发邮件

Mysql 设置 慢SQL时间并触发邮件

2025/1/21 16:16:44 来源:https://blog.csdn.net/xu990128638/article/details/145209652  浏览:    关键词:Mysql 设置 慢SQL时间并触发邮件

Mysql 设置 慢SQL时间,并触发邮件

1. 临时设置(会话级别)
SET SESSION long_query_time = 2; -- 设置慢查询时间为2秒
2. 全局设置
这样所有会话都会受到影响:
SET GLOBAL long_query_time = 2; -- 设置慢查询时间为2秒
3. 检查当前设置
SHOW VARIABLES LIKE 'long_query_time';
-- 或者
select @@long_query_time;

以上的问题,MySQL 服务重启后 失效。

4. 配置文件配置

为了确保设置在服务器重启后仍然有效,可以在 MySQL 配置文件(如 my.cnf 或 my.ini)中添加以下行:

[mysqld]
slow_query_log = 1
slow_query_log_file = /path/to/your/slow-query.log
long_query_time = 2  # 设置慢查询时间为2秒
log_queries_not_using_indexes = 1  # 可选:记录未使用索引的查询
5. 重启MySQL服务

保存配置文件并重启MySQL服务以使更改生效。

6. 编写Python 触发邮件代码
import time
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart# 配置邮件发送信息
SMTP_SERVER = 'smtp.example.com'
SMTP_PORT = 587
SMTP_USER = 'your-email@example.com'
SMTP_PASSWORD = 'your-email-password'
FROM_EMAIL = 'your-email@example.com'
TO_EMAIL = 'recipient-email@example.com'# 慢查询日志文件路径
SLOW_QUERY_LOG_FILE = '/path/to/your/slow-query.log'# 记录上次读取的位置
last_position = 0def send_email(subject, body):msg = MIMEMultipart()msg['From'] = FROM_EMAILmsg['To'] = TO_EMAILmsg['Subject'] = subjectmsg.attach(MIMEText(body, 'plain'))with smtplib.SMTP(SMTP_SERVER, SMTP_PORT) as server:server.starttls()server.login(SMTP_USER, SMTP_PASSWORD)server.sendmail(FROM_EMAIL, TO_EMAIL, msg.as_string())def monitor_slow_query_log():global last_positionwith open(SLOW_QUERY_LOG_FILE, 'r') as file:file.seek(last_position)while True:line = file.readline()if not line:time.sleep(1)  # 等待1秒后再次检查continuelast_position = file.tell()if 'Query_time:' in line:query_time = float(line.split('Query_time:')[1].split()[0])if query_time > 2:  # 假设慢查询时间阈值为2秒slow_query = line.strip()send_email('Slow Query Detected', f'Slow Query: {slow_query}')if __name__ == '__main__':monitor_slow_query_log()

确保你已经安装了所需的Python库(如 smtplib 和 email),然后运行脚本:

7. 运行Python 代码
python monitor_slow_query_log.py
8. 使用系统工具

如果你不想编写脚本,可以使用一些系统工具来监控文件变化并发送邮件。例如,使用 inotifywait 和 mail 命令:
安装 inotify-tools
在Linux上安装 inotify-tools:

sudo apt-get install inotify-tools
9. 创建 monitor_slow_query.sh脚本
#!/bin/bashSLOW_QUERY_LOG_FILE="/path/to/your/slow-query.log"
SMTP_SERVER="smtp.example.com"
SMTP_PORT=587
SMTP_USER="your-email@example.com"
SMTP_PASSWORD="your-email-password"
FROM_EMAIL="your-email@example.com"
TO_EMAIL="recipient-email@example.com"inotifywait -m -e modify "$SLOW_QUERY_LOG_FILE" |
while read path action file; dotail -n 1 "$SLOW_QUERY_LOG_FILE" | grep 'Query_time:' | while read line; doquery_time=$(echo $line | awk '{print $2}' | cut -d':' -f2)if (( $(echo "$query_time > 2" | bc -l) )); thenecho "Slow Query: $line" | mail -s "Slow Query Detected" -S smtp="$SMTP_SERVER:$SMTP_PORT" -S smtp-auth=login -S smtp-auth-user="$SMTP_USER" -S smtp-auth-password="$SMTP_PASSWORD" -S from="$FROM_EMAIL" "$TO_EMAIL"fidone
done

执行脚本

chmod +x monitor_slow_query.sh
./monitor_slow_query.sh

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com