生产环境的有些sql查询写得太复杂,或是表很大,对应索引未建立或建立不合理,或是查询未充分使用索引等,就有可能出现慢查询,一些慢查询需要修改程序,可能没那么快能解决,这时如果有个脚本能自动检测符合条件的慢查询会话并结束,那么是很方便的,当然运维人员也可顺便弄个检测慢查询并告警的脚本。

涉及知识点

mysql慢查询会话查询

schedule定时任务调度

pymysql执行sql

代码分解

mysql慢查询

#会话查询,只能查询所有会话,不能按条件过滤,不过比较好记

show PROCESSLIST;

#从information_schema中查询会话,可以按条件过滤

SELECT

*

FROM

information_schema.`PROCESSLIST`;

#查询符合条件的慢会话,id是会话ID,info是正在执行的sql,time是会话持续时间,杀会话时注意要做好过滤

SELECT

id,

info,

time

FROM

information_schema.`PROCESSLIST`

WHERE

info LIKE '%select * from table%'

AND time > 10;

#直接使用sql批量杀会话,拼接kill xxx;后,拷贝了在控制台执行

SELECT

concat('KILL ', id, ';')

FROM

information_schema.`PROCESSLIST`

WHERE

info LIKE '%select * from table%'

AND time > 10;

脚本主入口

if __name__ == '__main__':

#每5秒执行检查任务

schedule.every(5).seconds.do(kill_slow)

#此处固定写法,意思是每秒钟schedule看下是否有pending的任务,有就执行

while True:

schedule.run_pending()

time.sleep(1)

schedule的其它示例

import schedule

import time

def job(message='stuff'):

print("I'm working on:", message)

#每10分钟

schedule.every(10).minutes.do(job)

#每小时

schedule.every().hour.do(job, message='things')

#每天10点30分

schedule.every().day.at("10:30").do(job)

while True:

schedule.run_pending()

time.sleep(1)

pymysql使用

# 连接数据库,设置结果集用dict返回,autocommit自动提交事务

db = pymysql.connect(host='localhost', db='dbname',

user='root', passwd='admin',

port=3306, charset='utf8',

cursorclass=pymysql.cursors.DictCursor, autocommit=True)

cursor = db.cursor()

查询符合条件的慢会话并结束

def kill_slow():

cursor.execute(

"""

SELECT

id,

info,

time

FROM

information_schema.`PROCESSLIST`

WHERE

info LIKE '%select * from table%'

AND time > 10;

""")

slow_sessions = cursor.fetchall()

for slow_session in slow_sessions:

print("slow session detected, kill it:\n id:%s\nsql:%s" % (

slow_session[0], slow_session[1]))

cursor.execute("kill %s", slow_session[0])

完整代码

import time

import pymysql

import schedule

# 连接数据库,设置结果集用dict返回,autocommit自动提交事务

db = pymysql.connect(host='localhost', db='dbname',

user='root', passwd='admin',

port=3306, charset='utf8',

cursorclass=pymysql.cursors.DictCursor, autocommit=True)

cursor = db.cursor()

def kill_slow():

cursor.execute(

"""

SELECT

id,

info,

time

FROM

information_schema.`PROCESSLIST`

WHERE

info LIKE '%select * from table%'

AND time > 10;

""")

slow_sessions = cursor.fetchall()

for slow_session in slow_sessions:

print("slow session detected, kill it:\n id:%s\nsql:%s" % (

slow_session[0], slow_session[1]))

cursor.execute("kill %s", slow_session[0])

if __name__ == '__main__':

# 每5秒执行检查任务

schedule.every(5).seconds.do(kill_slow)

# 此处固定写法,意思是每秒钟schedule看下是否有pending的任务,有就执行

while True:

schedule.run_pending()

time.sleep(1)

总结

以上所述是小编给大家介绍的python自动结束mysql慢查询会话的实例代码,希望对大家有所帮助!

python 连接数据库 慢_python自动结束mysql慢查询会话的实例代码相关推荐

  1. python woe分箱_python自动分箱,计算woe,iv的实例代码

    笔者之前用R开发评分卡时,需要进行分箱计算woe及iv值,采用的R包是smbinning,它可以自动进行分箱.近期换用python开发, 也想实现自动分箱功能,找到了一个woe包,地址https:// ...

  2. php mysql PDO 查询操作的实例详解

    php mysql PDO 查询操作的实例详解 ? 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 ...

  3. pdo mysql 绑定查询_php mysql PDO 查询操作的实例详解

    php mysql PDO 查询操作的实例详解 php mysql PDO 查询操作的实例详解 这篇文章主要介绍了php mysql PDO 查询操作的实例详解的相关资料,希望通过本文能帮助到大家,需 ...

  4. python怎么操作_python怎么操作mysql

    pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x,而MySQLdb不支持3.x版本. 本文测试python版本:3.6. ...

  5. python线程退出_python子线程退出及线程退出控制的代码

    下面通过代码给大家介绍python子线程退出问题,具体内容如下所示: def thread_func(): while True: #do something #do something #do so ...

  6. python getopt使用_Python命令行参数解析模块getopt使用实例

    这篇文章主要介绍了Python命令行参数解析模块getopt使用实例,本文讲解了使用语法格式.短选项参数实例.长选项参数实例等内容,需要的朋友可以参考下 格式 getopt(args, options ...

  7. python对逻辑回归进行显著性_python sklearn库实现简单逻辑回归的实例代码

    Sklearn简介 Scikit-learn(sklearn)是机器学习中常用的第三方模块,对常用的机器学习方法进行了封装,包括回归(Regression).降维(Dimensionality Red ...

  8. python获取电脑几核几线程_python编程测试电脑开启最大线程数实例代码

    本文实例代码主要实现python编程测试电脑开启最大线程数,具体实现代码如下. #!/usr/bin/env python #coding=gbk import threading import ti ...

  9. python导入文件列行_python读写csv文件并增加行列的实例代码

    python读写csv文件并增加行列,具体代码如下所示: # -*- coding: utf-8 -*- """ Created on Thu Aug 17 11:28: ...

  10. python测试电脑性能的代码_python编程测试电脑开启最大线程数实例代码

    本文实例代码主要实现python编程测试电脑开启最大线程数,具体实现代码如下. #!/usr/bin/env python #coding=gbk import threading import ti ...

最新文章

  1. linux 端口 流量统计,Linux下如何对端口流量进行统计
  2. href=#与href=javascript:void(0)的区别
  3. javascript之值传递与引用传递
  4. priority_queue
  5. 日常生活小技巧 -- 名词
  6. redis 慢查询日志
  7. 初二物理模型有哪些_初二是成绩下滑的高危期,做好这5点成绩涨涨涨!(附全学科提升技巧,家长转给孩子!)...
  8. Hills And Valleys CodeForces - 1467B 思维
  9. 【C语言笔记初级篇】第三章:函数与递归
  10. AR的一些常见的操作
  11. Linux下Birt、JTreeChart中文乱码问题解决办法
  12. 【斐波那切数列】LeetCode 70. Climbing Stairs
  13. SQL数据分析常用案例总结
  14. 马云收购士兰微_马云出手!阿里36亿拿下千方科技
  15. 彻底关闭Windows更新
  16. 集线器Hub、交换机Switch 和 路由器Router 的区别
  17. composer镜像源切换
  18. 后分库分表时代的数据库新选择:二维火搭载OceanBase再出发
  19. 学python的书-学习python求推荐一波书籍?
  20. 一个应用程序有多少个进程

热门文章

  1. Linux笔记1 修改主机名、ip以及指DNS
  2. MySQL对分隔符的处理(一)
  3. 服务器无法分配系统页面缓冲池中的内存
  4. Qt学习之路(21): event()
  5. 举例说明计算机网络协议,第二章计算机网络协议与体系结构.ppt
  6. 图标圆角角度_教你在 iOS 和 macOS 上获取 App 图标
  7. linux内核percpu变量声明,Linux内核对per-cpu变量的实现
  8. elementui的横向滚动_记一次element-ui配置化table组件的适应性问题(横向滚动条)...
  9. centos7下yum安装mysql_CentOS7下使用YUM安装MySQL5.6-Go语言中文社区
  10. 你对Redis持久化了解多少?一篇文章让你明白Redis持久化