mysql 性能监控 jav_数据库调优教程(三)记录慢查询

3.      记录慢查询

此时我们已经有让慢查询发生的成本了。执行以下语句,你就知道什么叫慢!查!询!

select empno from emp where ename='';

0a8e2062144eda40338a88ba1ead456f.png

一个很明显找不到结果的查询语句居然也执行了近3秒钟。

这时候,作为DBA就应该把这个sql语句记录下来,是记在记事本还是写在笔记本呢?不用想太多了,不用你自己记,Mysql提供了慢查询日志功能,自动帮你记录慢查询的语句。

1)    把慢查询的sql记录到日志中

首先你要打开慢查询日志文件记录器

使用

show variables like 'slow%';

你会发现默认情况下慢查询日志记录器关闭的

使用

set global slow_query_log=ON;

打开之

f430f5b5064786571640339a5d9bc3f0.png

此时你会发现mysql安装目录下的data文件夹中出现了以你本机名命名的日志文件

1bc3ec6deae0db9c9302afbee7aa47cf.png

此时再执行慢查询操作

1dce4aa0ba3744f6611abf7a34c147d3.png

打开日志文件发现出现记录

c896fe539eb413b0a608e4270fc30db9.png

以后只需要定期检查日志文件就可以找到慢查询语句了

注意:

在找到慢查询语句后,要通过反复使用select语句确认慢查询,注意只能使用select语句,就算是原来语句为delete或者update等,也要用select代替,因为只有select不会弄脏数据库

2)    另一种发现慢查询语句的方法

要是你使用Hibernate进行J2ee开发,可以使用一下方式。

在页面中进行操作,当发现某个操作的响应较慢时,查看Eclipse控制台的Hibernate输出sql语句,此语句即为慢查询语句。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值