php教程 php手册 MYSQL的慢查询分析

MYSQL的慢查询分析

Jul 06, 2016 pm 01:29 PM

本文转自http://www.libazh.com/?p=18 一个带新手上路的博客
有一段日子了,曾经设置了一次记录在mysql中查询慢于1秒钟的SQL语句。刚才突然回想设置的方法,有几个参数的名称死活回忆不起来了,于是重新整理一下,自己做个笔记。

对于排查问题找出性能瓶颈来说,最容易发现并解决的问题就是MYSQL的慢查询以及没有得用索引的查询。

OK,开始找出mysql中执行起来不“爽”的SQL语句吧。
转至新手博客 ; http://www.libazh.com/?p=18
方法一: 这个方法我正在用,呵呵,比较喜欢这种即时性的。

Mysql5.0以上的版本可以支持将执行比较慢的SQL语句记录下来。mysql&gt; show variables like 'long%';     注:这个long_query_time是用来定义慢于多少秒的才算“慢查询”<br> +-----------------+-----------+<br> | Variable_name   | Value     |<br> +-----------------+-----------+<br> | long_query_time | 10.000000 | <br> +-----------------+-----------+<br> 1 row in set (0.00 sec)mysql&gt; set long_query_time=1;   注: 我设置了1, 也就是执行时间超过1秒的都算慢查询。<br> Query OK, 0 rows affected (0.00 sec)mysql&gt; show variables like 'slow%';<br> +---------------------+---------------+<br> | Variable_name       | Value         |<br> +---------------------+---------------+<br> | slow_launch_time    | 2             | <br> | slow_query_log      | ON            |           注:是否打开日志记录<br> | slow_query_log_file | /tmp/slow.log |      注: 设置到什么位置<br> +---------------------+---------------+<br> 3 rows in set (0.00 sec)mysql&gt; set global slow_query_log='ON'   注:打开日志记录一旦slow_query_log变量被设置为ON,mysql会立即开始记录。

/etc/my.cnf 里面可以设置上面MYSQL全局变量的初始值。long_query_time=1<br> slow_query_log_file=/tmp/slow.log====================================================

方法二:mysqldumpslow命令/path/mysqldumpslow -s c -t 10 /tmp/slow-log这会输出记录次数最多的10条SQL语句,其中:-s, 是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序,ac、at、al、ar,表示相应的倒叙;<br> -t, 是top n的意思,即为返回前面多少条的数据;<br> -g, 后边可以写一个正则匹配模式,大小写不敏感的;<br> 比如<br> /path/mysqldumpslow -s r -t 10 /tmp/slow-log<br> 得到返回记录集最多的10个查询。<br> /path/mysqldumpslow -s t -t 10 -g “left join” /tmp/slow-log<br> 得到按照时间排序的前10条里面含有左连接的查询语句。搞定!
本文转自 http://www.libazh.com/?p=18 一个带新手上路的博客

云栖大会北京站:阿里技术专家难得出镜,这次一下来了100多位?!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Python 프로그래밍을 위한 소개 코드 예제에 대해 알아보세요. Python 프로그래밍을 위한 소개 코드 예제에 대해 알아보세요. Jan 04, 2024 am 10:50 AM

Python 프로그래밍을 위한 소개 코드 예제에 대해 알아보세요.

실제 사용되는 PHP 변수: 실제 사용 사례 10가지 실제 사용되는 PHP 변수: 실제 사용 사례 10가지 Feb 19, 2024 pm 03:00 PM

실제 사용되는 PHP 변수: 실제 사용 사례 10가지

PHP를 사용하여 재고 관리 시스템에서 재고 관리 기능 코드를 작성하는 방법 PHP를 사용하여 재고 관리 시스템에서 재고 관리 기능 코드를 작성하는 방법 Aug 06, 2023 pm 04:49 PM

PHP를 사용하여 재고 관리 시스템에서 재고 관리 기능 코드를 작성하는 방법

초보자부터 숙련자까지: Go 언어에서 일반적으로 사용되는 데이터 구조의 코드 구현 초보자부터 숙련자까지: Go 언어에서 일반적으로 사용되는 데이터 구조의 코드 구현 Mar 04, 2024 pm 03:09 PM

초보자부터 숙련자까지: Go 언어에서 일반적으로 사용되는 데이터 구조의 코드 구현

Java는 간단한 버블 정렬 코드를 구현합니다. Java는 간단한 버블 정렬 코드를 구현합니다. Jan 30, 2024 am 09:34 AM

Java는 간단한 버블 정렬 코드를 구현합니다.

Go 언어 프로그래밍 예제: 웹 개발의 코드 예제 Go 언어 프로그래밍 예제: 웹 개발의 코드 예제 Mar 04, 2024 pm 04:54 PM

Go 언어 프로그래밍 예제: 웹 개발의 코드 예제

Huawei Cloud Edge Computing 상호 연결 가이드: 인터페이스를 빠르게 구현하기 위한 Java 코드 예제 Huawei Cloud Edge Computing 상호 연결 가이드: 인터페이스를 빠르게 구현하기 위한 Java 코드 예제 Jul 05, 2023 pm 09:57 PM

Huawei Cloud Edge Computing 상호 연결 가이드: 인터페이스를 빠르게 구현하기 위한 Java 코드 예제

지침 및 예: Java에서 선택 정렬 알고리즘을 구현하는 방법 알아보기 지침 및 예: Java에서 선택 정렬 알고리즘을 구현하는 방법 알아보기 Feb 18, 2024 am 10:52 AM

지침 및 예: Java에서 선택 정렬 알고리즘을 구현하는 방법 알아보기

See all articles