开启MySQL慢查询及分析工具

本文介绍如何通过慢查询日志来发现并优化执行效率低下的SQL语句,包括开启慢查询日志的方法、日志内容解析及常用分析工具。

1.慢查询的作用:帮我们找到执行慢的SQL语句,方便我们对SQL语句进行优化
2.慢查询日志的文件增长非常长,生产环境建议及时清理,一天可能会达到几G或者更多
3.日志可以说明大部分问题,但不是说明一切问题,可能跟锁表、系统繁忙的偶发性有关。当然,某条SQL语句经常查询慢那基本是可以再次优化的

  • 通过命令开启慢查询日志
// 查询是否开启慢查询 ON OR OFF
show variables like 'log_slow_queries'
// 查询是否开启慢查询日志 ON OR OFF
show variables like 'show_query_log'
// 指定慢查询日志的存储位置 目录要具有写权限
set global show_query_log_file = '/home/mysql/sql_log/mysql-slow.log'
// 把没有使用索引的sql记录到慢查询日志中 如果table的数据量小,不建议开启该条设置,因为会记录所有没有用到索引的查询,会给日志填充很多垃圾信息
set global log_queries_not_using_indexes = on;
// 超过1秒钟查询记录到慢查询日志中
set global long_query_time = 1;
  • 通过my.ini开启慢查询日志(原理和用命令一样),不过配置完成需要重启MySQL
目录要具有写权限
log-slow-queries = '/home/mysql/sql_log/mysql-slow.log'
// 在windows的情况下需要绝对路径
log-slow-queries = 'C:/Program Files/MySQL/MySQL Server 5.5/log/mysql-slow.log'
long_query_time = 1
log-queries-not-using-indexes = on
  • 慢查询日志所包含的内容
// 执行SQL的主机信息:ROOT用户在本地所执行的查询
# User@Host: root['root'] @ localhost []
// SQL的执行信息 查询时间、锁定时间、发送行数、扫描行数
# Query_time:0.000024 Lock_time:0.0000000 Rows_sent:0 Rows_examined:0
// SQL执行时间 时间戳
# SET timestamp = 1402389328;
// SQL的内容
# select CONCAT('storage engine:',@@storage_engine) as INFO;
  • 慢查询日志分析工具
    工具1:mysqldumpslow(官方工具) 一般集成在MySQL安装包中
    直接使用mysqldumpslow命令即可使用

    工具2:pt-query-digest工具
    输入命令系统提示没有的话可以查找安装一下

    工具3:自己写脚本将日志中的语句列出来,通过网页的形式查看
### SAS硬盘SATA硬盘区别对比 #### 1. 接口类型与物理连接 SAS(Serial Attached SCSI)SATA(Serial ATA)都是采用串行技术的存储接口,但它们在物理连接上存在差异。SAS接口支持全双工通信,允许同时进行读写操作,而SATA通常为半双工通信[^3]。此外,SAS接口设计支持多设备连接,适合企业级服务器环境,而SATA更倾向于单设备直连,适用于个人计算机或非关键业务场景。 #### 2. 数据传输速度 SAS硬盘的数据传输速率通常高于SATA硬盘。当前主流的SAS硬盘支持12 Gbps甚至更高的传输速率,而SATA硬盘一般停留在6 Gbps的水平[^2]。这种差异使得SAS硬盘更适合需要高吞吐量的应用场景,如数据库服务器、虚拟化平台等。 #### 3. 可靠性与耐用性 SAS硬盘在设计上更加注重可靠性,通常具备更高的MTBF(平均无故障时间),并且支持更严格的错误检测纠正机制。相比之下,SATA硬盘虽然在可靠性方面有所提升,但仍主要用于对成本敏感的消费级市场[^1]。因此,在高负载、长时间运行的环境中,SAS硬盘表现出更强的稳定性耐久性。 #### 4. 应用领域 由于上述特点,SAS硬盘广泛应用于企业级服务器、存储阵列性能计算环境,而SATA硬盘则更多地用于个人电脑、家庭存储设备以及对性能要求不高的中小型企业应用。SAS硬盘还支持更复杂的命令队列管理功能,如NCQ(Native Command Queuing),这有助于优化多任务处理时的I/O性能[^2]。 #### 5. 成本因素 SAS硬盘的制造成本较高,价格也相对昂贵,主要面向高端市场。而SATA硬盘因生产规模大、技术成熟度高,成本较低,适合预算有限的用户或对性能要求不高的场景[^3]。 #### 6. 硬盘标识与外观 从外观上看,SATA硬盘通常会在标签中标明“SERIAL SATA”字样,并显示容量、工作电压电流等信息。而SAS硬盘的标识可能更为复杂,包含更多的技术参数以适应其专业用途[^1]。 ```python # 示例代码:模拟SASSATA硬盘性能对比 class Disk: def __init__(self, type, speed): self.type = type self.speed = speed def get_performance(self): return f"{self.type} Disk Performance: {self.speed} Gbps" sas_disk = Disk("SAS", 12) sata_disk = Disk("SATA", 6) print(sas_disk.get_performance()) # 输出SAS硬盘性能 print(sata_disk.get_performance()) # 输出SATA硬盘性能 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值