目次
慢查询日志
打开慢查询日志
保存慢查询日志到表中
慢查询日志分析
Percona Toolkit介绍
安装
pt-query-digest
pt-index-usage
pt-upgrade
pt-query-advisor 
SHOW PROFILE
performance_schema
ホームページ データベース mysql チュートリアル MySQL优化—工欲善其事,必先利其器(2)_MySQL

MySQL优化—工欲善其事,必先利其器(2)_MySQL

Jun 01, 2016 pm 01:26 PM
記事

bitsCN.com

上一篇文章简单介绍了下EXPLAIN的用法,今天主要介绍以下几点内容:

慢查询日志

  • 打开慢查询日志
  • 保存慢查询日志到表中
  • 慢查询日志分析

Percona Toolkit介绍

  • 安装
  • pt-query-digest
  • pt-index-usage
  • pt-query-advisor

SHOW PROFILE

performance_schema

 

慢查询日志

打开慢查询日志

慢查询日志,顾名思义就是记录执行比较慢查询的日志。

查看是否开启慢查询日志:

show variables like '%slow%';
ログイン後にコピー

打开慢查询日志。修改MySQL的配置文件my.cn一般是在/etc目录下面,加上下面三行配置后重启MySQL。

slow_query_log = ONslow-launch-time = 2slow-query-log-file = /usr/local/mysql/data/slow_query.log
ログイン後にコピー

slow_launch_time只能精确到秒,如果需要更精确可以使用一些第三方的工具比如后面介绍的pt-query-digest。

注意:我这里用的MySQL版本是5.6,不同版本的MySQL开启慢查询的配置是不同的,比如5.6之前的某些版本是ong_query_time, long_query_time和log-slow-queries。可以先在终端执行show variables like '%slow%';查看下当前版本具体配置是什么。

也可以在终端通过设置全局变量来打开慢查询日志:

set  @@global.slow_query_log = ON;
ログイン後にコピー

保存慢查询日志到表中

MySQL支持将慢查询日志保存到mysql.slow_log这张表中。通过@@global.log_output可以设置默认为TABLE,FILE和TABLE只能同时使用一个。

set @@global.log_output='TABLE';
ログイン後にコピー

我们可以使用下面的语句来模拟慢查询:

select sleep(10);
ログイン後にコピー

慢查询日志分析

1、可以使用MySQL自带的mysqldumpslow工具。使用很简单,可以跟-help来查看具体的用法。

# -s:排序方式。c , t , l , r 表示记录次数、时间、查询时间的多少、返回的记录数排序;#                             ac , at , al , ar 表示相应的倒叙;# -t:返回前面多少条的数据;# -g:包含什么,大小写不敏感的;mysqldumpslow -s r -t 10  /slowquery.log     #slow记录最多的10个语句mysqldumpslow -s t -t 10 -g "left join"  /slowquery.log     #按照时间排序前10中含有"left join"的
ログイン後にコピー

2、可以导到mysql.slow_query表中,然后通过sql语句进行分析。

3、使用第三方工具,下面会有介绍。

 

Percona Toolkit介绍

percona-toolkit是一组高级命令行工具的集合,用来执行各种通过手工执行非常复杂和麻烦的mysql和系统任务。这些任务包括:

  • 检查master和slave数据的一致性
  • 有效地对记录进行归档
  • 查找重复的索引
  • 对服务器信息进行汇总
  • 分析来自日志和tcpdump的查询
  • 当系统出问题的时候收集重要的系统信息

安装

安装percona-toolkit非常简单,到官网下载.tar.gz包:

wget percona.com/get/percona-toolkit.tar.gztar -zxvf percona-toolkit-2.2.5.tar.gz
ログイン後にコピー

然后依次执行下面的命令:

perl Makefile.PLmakemake testmake install
ログイン後にコピー

默认的会被安装在/usr/local/bin目录下。执行man percona-toolkit可以查看安装了哪些工具。

运行工具可能会遇到下面的错误:

这是因为缺少相应包,.pm包实际上perl的包,运行下面的命令安装即可:

yum install -y perl-Time-HiRes
ログイン後にコピー

如果安装过程中出现” Error Downloading Packages”错误,尝试yum clean all后再安装。使用其Percona Toolkit中其他工具也可能会遇到类似的问题,按照提示安装相应的perl包就可以了。

Percona Toolkit整个工具箱提供了非常多实用的工具,具体的使用方法可以参看官方文档。

下面有选择的给大家介绍几个有用的工具。

pt-query-digest

pt-query-digest可以从普通MySQL日志,慢查询日志以及二进制日志中分析查询,甚至可以从SHOW PROCESSLIST和MySQL协议的tcpdump中进行分析,如果没有指定文件,它从标准输入流(STDIN)中读取数据。

最简单的用法如下:

pt-query-digest slow.logs
ログイン後にコピー

输出信息大致如下:

整个输出分为三大部分:

1、整体概要(Overall)

这个部分是一个大致的概要信息(类似loadrunner给出的概要信息),通过它可以对当前MySQL的查询性能做一个初步的评估,比如各个指标的最大值(max),平均值(min),95%分布值,中位数(median),标准偏差(stddev)。这些指标有查询的执行时间(Exec time),锁占用的时间(Lock time),MySQL执行器需要检查的行数(Rows examine),最后返回给客户端的行数(Rows sent),查询的大小。

2、查询的汇总信息(Profile)

这个部分对所有”重要”的查询(通常是比较慢的查询)做了个一览表:

每个查询都有一个Query ID,这个ID通过Hash计算出来的。pt-query-digest是根据这个所谓的Fingerprint来group by的。举例下面两个查询的Fingerprint是一样的都是select * from table1 where column1 = ?,工具箱中也有一个与之相关的工具pt-fingerprint。

select * from table1 where column1 = 2select * from table1 where column1 = 3
ログイン後にコピー
  • Rank整个分析中该“语句”的排名,一般也就是性能最常的。
  • Response time  “语句”的响应时间以及整体占比情况。
  • Calls 该“语句”的执行次数。
  • R/Call 每次执行的平均响应时间。
  • V/M 响应时间的差异平均对比率。

在尾部有一行输出,显示了其他2个占比较低而不值得单独显示的查询的统计数据。

3、详细信息

这个部分会列出Profile表中每个查询的详细信息:

包括Overall中有的信息、查询响应时间的分布情况以及该查询”入榜”的理由。

pt-query-digest还有很多复杂的操作,这里就不一一介绍了。比如:从PROCESSLIST中查询某个MySQL中最慢的查询:

pt-query-digest –processlist h=host1
ログイン後にコピー

从tcpdump中分析:

tcpdump -s 65535 -x -nn -q -tttt -i any -c 1000 port 3306 > mysql.tcp.txtpt-query-digest --type tcpdump mysql.tcp.txt
ログイン後にコピー

从一台机器上讲slow log保存到另外一台机器上待稍后详细分析:

pt-query-digest --review h=host2 --no-report slow.log
ログイン後にコピー

还可以跟一些过滤条件。详见官方文档:http://www.percona.com/doc/percona-toolkit/2.2/pt-query-digest.html

另外结合一些第三方工具还能生成相应的报表,可以参考这里:http://biancheng.dnbcw.info/mysql/433514.html

建议:当slow log很大的时候最好还是将日志文件移到其他机器上进行分析。

 

pt-index-usage

这个工具主要是用来分析查询的索引使用情况。

pt-index-usage slow_query.log --h localhost --password 123456
ログイン後にコピー

详细的用法 –help查看再对照官网就差不再赘述。

注意使用这个工具需要MySQL必须要有密码,另外运行时可能报找不到/var/lib/mysql/mysql.sock的错,简单的从/tmp/mysql.sock链接一个就行了。

重点要说明的是pt-index-usage只能分析慢查询日志,所以如果想全面分析所有查询的索引使用情况就得将slow_launch_time设置为0,因此请谨慎使用该工具,线上使用的话最好在凌晨进行分析,尤其分析大量日志的时候是很耗CPU的。

整体来说这个工具是不推荐使用的,要想实现类似的分析可以考虑一些其他第三方的工具,比如:mysqlidxchx, userstat和check-unused-keys。网上比较推荐的是userstat,一个Google贡献的patch。

Oracle是可以将执行计划保存到性能视图中的,这样分析起来可能更灵活,但是目前我还没找到MySQL中类似的做法。

 

pt-upgrade

这个工具用来检查在新版本中运行的SQL是否与老版本一样,返回相同的结果,最好的应用场景就是数据迁移的时候。

pt-upgrade h=host1 h=host2 slow.log
ログイン後にコピー

 

pt-query-advisor 

静态查询分析工具。能够解析查询日志、分析查询模式,然后给出所有可能存在潜在问题的查询,并给出足够详细的建议。这个工具好像2.2的版本给去掉了,有可能是因为对性能影响比较大新版本直接去掉了。

总结:上面这些工具最好不要直接在线上使用,应该作为上线辅助或故障后离线分析的工具,也可以做性能测试的时候配合着使用。

 

SHOW PROFILE

SHOW PROFILE是Google高级架构师Jeremy Cole贡献给MySQL社区的,它可以用来MySQL执行语句时候所使用的资源。默认是关闭的,需要打开执行下面的语句:

set profiling = 1;#这个命令只在本会话内起作用。
ログイン後にコピー

执行简单的SHOW PROFILES可以看到打开profiling之后所有查询的执行时间。

执行SHOW PROFILE [TYPE] FOR QUERY Query_ID可以看到MySQL执行某个查询各个步骤的各项性能指标的详细信息:

如果没有指定FOR QUERY则显示最近一条查询的详细信息。TYPE是可选的,有以下几个选项:

  • ALL 显示所有性能信息
  • BLOCK IO 显示块IO操作的次数
  • CONTEXT SWITCHES 显示上下文切换次数,不管是主动还是被动
  • CPU 显示用户CPU时间、系统CPU时间
  • IPC 显示发送和接收的消息数量
  • MEMORY [暂未实现]
  • PAGE FAULTS 显示页错误数量
  • SOURCE 显示源码中的函数名称与位置
  • SWAPS 显示SWAP的次数

MySQL在执行查询语句的时候会有很多步骤,这里就不一一赘述了,用到的时候网上搜下就行。需要特别说明的是Sending data这个步骤,给人感觉是MySQL把数据发送给客户端的耗时,其实不然,这个步骤包括了MySQL内部各个存储之间复制数据的过程,比如硬盘的寻道。

总结:前面的慢查询日志分析更像是对整个MySQL查询情况做一个全面的检查,而SHOW PROFILE则是对单个查询语句的剖析,通常当现网出现问题时应该结合二者。使用慢查询分析定位到具体的查询,使用SHOW PROFILE定位到具体的问题,是Sending data比较耗时还是System lock比较耗时...

 

performance_schema

这两个库保存了MySQL的一些性能和元数据相关的信息,其中performance_schema是MySQL5.5才新增的,上面提到的很多工具其实利用了这个库的信息。比如SHOW PROFILE ALL FOR QUERY 2:的信息还可以通过下面的查询获取:

SELECT * FROM information_schema.profiling WHERE query_id = 2 ORDER BY seq;
ログイン後にコピー

利用performance_schema还可以做一些更灵活的统计:

SET @query_id = 1;SELECT STATE,SUM(DURATION) AS Total_R,    ROUND(100*SUM(DURATION)/(SELECT SUM(DURATION) FROM INFORMATION_SCHEMA.PROFILING    WHERE QUERY_ID = @query_id),2) AS Pct_R,    COUNT(*) AS Calls,    SUM(DURATION)/COUNT(*) AS "R/Call"FROM INFORMATION_SCHEMA.PROFILINGWHERE QUERY_ID = @query_idGROUP BY STATEORDER BY Total_R DESC;
ログイン後にコピー

这个简单的查询可以在《高性能MySQL第三版》中找到,可它能统计SHOW PROFILE各个步骤的耗时、耗时占比、调用API次数以及每次的平均耗时。在《高性能MySQL第三版》中还提到了很多有用的工具包括使用方法,强烈推荐这本书。

 

Ok,今天的介绍就到这里,这两篇文章的主要目的是希望自己在发现问题的时候可以知道从何下手,也希望能够大家带来一些实用价值。下一篇准备介绍一下MySQL执行语句的一些基本原理,俗话说磨刀不误砍柴工嘛!

 

 

 

bitsCN.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

今すぐ Toutiao の記事を公開してお金を稼ぐにはどうすればよいですか?今すぐ Toutiao で記事を公開して収入を増やす方法! 今すぐ Toutiao の記事を公開してお金を稼ぐにはどうすればよいですか?今すぐ Toutiao で記事を公開して収入を増やす方法! Mar 15, 2024 pm 04:13 PM

1. 今すぐ Toutiao の記事を公開してどうやってお金を稼ぐことができますか?今すぐ Toutiao で記事を公開して収入を増やす方法! 1. 基本的な権利と利益の有効化: オリジナルの記事は広告によって利益を得ることができますが、利益を得るにはビデオが横画面モードでオリジナルである必要があります。 2. ファン100人の権利を有効化:ファン数が100人以上に達すると、マイクロヘッドライン、オリジナルQ&A作成、Q&Aから利益を得ることができます。 3. オリジナル作品にこだわる: オリジナル作品には記事、小見出し、質問などが含まれ、300 ワード以上であることが求められます。違法に盗用された作品をオリジナル作品として出版した場合、クレジットポイントが減点され、利益も差し引かれますのでご注意ください。 4. 垂直性:専門分野の記事を書く場合、分野を超えて自由に記事を書くことができず、適切な推薦が得られず、専門性や洗練度が得られず、ファンもつきにくいそして読者たち。 5. 活動: 高活動、

HTML5で記事を追加するにはどうすればよいですか? HTML5で記事を追加するにはどうすればよいですか? Sep 12, 2023 am 11:37 AM

この記事では、HTML5 で記事を追加する方法を学びます。 HTML5 の新しいセグメンテーション要素の 1 つはタグです。記事はタグを使用して HTML で表現されます。より具体的には、要素内に含まれるコンテンツは、サイトの残りのコンテンツとは (たとえ関連しているとしても) 異なります。 HTML5 に記事を追加する方法を理解するために、次の例を考えてみましょう。 例 1 次の例では、article 要素でインライン スタイルを使用しています。 <!DOCTYPEhtml><html><body><articlestyle="width:300px;border:2pxsolidgray;padding:

Vitalik の新しい記事の解釈: BLOB 領域が効率的に使用されていない Rollup はなぜ開発困難に陥るのか? Vitalik の新しい記事の解釈: BLOB 領域が効率的に使用されていない Rollup はなぜ開発困難に陥るのか? Apr 01, 2024 pm 08:16 PM

イーサリアムの拡張に関する @VitalikButerin の新しい記事の考えを理解するにはどうすればよいでしょうか?ヴィタリックのブロブ碑文の注文はとんでもないという人もいます。では、BLOB パケットはどのように機能するのでしょうか?カンクンでのアップグレード後に BLOB スペースが効率的に使用されないのはなぜですか?シャーディングの準備として DAS データの可用性をサンプリングしますか?私の意見では、Cancun のパフォーマンスはアップグレード後も使用可能であり、Vitalik は Rollup の開発を心配しています。なぜ?次に、私の理解について話させてください: これまでに何度も説明したように、Blob は EVM の呼び出しデータから切り離されており、コンセンサス層によって直接呼び出すことができる一時的なデータ パッケージです。直接的な利点は、EVM がアクセスする必要がないことです。トランザクションの実行時に BLOB のデータが読み取られるため、実行層の計算が低下します。

WeChatで記事と録画を同時に送信する詳細な方法 WeChatで記事と録画を同時に送信する詳細な方法 Mar 26, 2024 am 09:16 AM

1. 携帯電話を開き、WeChat ソフトウェアをクリックして、WeChat ホームページの設定を入力します。 2. WeChat の右下隅にある [My] を見つけて開き、[My] ページに入ります。 3. 「コレクション」をクリックして、新しいページを開きます。

Toutiao Search Express Edition に記事を掲載すると儲かりますか? Toutiao Search Express Edition に記事を掲載すると儲かりますか? Feb 29, 2024 pm 04:16 PM

Toutiao Search Express ソフトウェアは、ユーザーが閲覧できる豊富な記事コンテンツを提供するだけでなく、ユーザーが自分自身を表現し、知識を共有するためのプラットフォームも提供します。多くのユーザーは、Toutiao Search Express Edition で記事を公開すると収益が得られるかどうか知りたいと考えているため、今日はこのサイトの編集者が Toutiao Search Express Edition で記事を公開すると収益が得られるかどうかと、記事の公開方法を詳しく紹介します。困っている人全員を助けてください。 Toutiao Search Express に記事を公開することで利益は得られますか? 回答: はい。 1. まず、Toutiao 検索速度バージョン ソフトウェアを開き、ホームページの右上隅にある [プラス アイコン] をクリックします; 2. 次に、記事公開ページが表示され、ビデオ、写真をアップロードできます、リンク、およびテキストの入力。お待ちください。すべてが設定されました

DreamWeaver CMS 記事の内容は失われますか?一回の動きで完了 DreamWeaver CMS 記事の内容は失われますか?一回の動きで完了 Mar 29, 2024 am 09:06 AM

DedeCMS は、大多数の Web サイト作成者に深く愛されている強力なオープンソース Web サイト コンテンツ管理システムです。しかし、使用中に記事の内容が失われる場合があり、サイト管理者にとっては多大なご迷惑をおかけしております。この記事では、DreamWeaver CMS で記事コンテンツが欠落する問題を解決する方法を紹介し、具体的なコード例を示して、この問題に遭遇した Web サイト管理者の助けになれば幸いです。問題の説明: Dreamweaver CMS を使用する過程で、記事のコンテンツが失われることがあります。可能

Dreamweaver CMS 記事のコンテンツが消えた場合はどうすればよいですか?素早い解決策 Dreamweaver CMS 記事のコンテンツが消えた場合はどうすればよいですか?素早い解決策 Mar 29, 2024 am 11:36 AM

DedeCMS は、さまざまな Web サイト構築で広く使用されている強力なオープンソース コンテンツ管理システムです。しかし、利用中に記事内容が消えてしまう場合があり、サイト運営者にご迷惑をおかけすることがあります。この記事では、DreamWeaver CMS で記事コンテンツが消える一般的な理由と簡単な解決策を紹介し、この問題の解決に役立つことを期待して、具体的なコード例を示します。 1. 記事コンテンツが消失する考えられる理由: データベース操作エラー: データベースに記事コンテンツを格納するテーブルが原因で発生する可能性があります。

PHP プログラミング スキル: 複数の記事に like 関数を実装する PHP プログラミング スキル: 複数の記事に like 関数を実装する Feb 27, 2024 pm 03:27 PM

タイトル: PHP プログラミング スキル: 複数の記事への「いいね!」機能の実装 Web サイト開発において、「いいね!」機能は一般的かつ重要な機能の 1 つであり、ユーザーの対話性を高め、ユーザー エクスペリエンスを向上させることができます。この記事では、PHP を使用して複数の記事にいいね! 機能を実装する方法について説明します。 PHP および MySQL データベースを使用してこの機能を実装し、読者が実装プロセスをよりよく理解できるように具体的なコード例を提供します。ステップ 1: データベースを作成する まず、記事の情報といいね数を保存するデータベースを作成する必要があります。私たちが作成します

See all articles