基本的な流れ
ここからは、分析系クエリのベンチマーク「TPC-H」です。
やりかたは、TPC-Cとほとんど同じなので、淡々と進めていきます。
TPC-Hは、定められた22本1セットの分析クエリ(要はMySQLがあまり得意としない複雑でデカイSQL)についての処理性能を見るベンチマークテストで、
- …
前回の、MySQL Technology Cafe #4 に続き、#5
に参加してきました。
タイムテーブル
| 時間 | 内容 | 登壇者 |
|---|---|---|
| 18:00-18:25 | 受付 | - |
| 18:25-18:30 | はじめに | MySQL GBU |
| 18:30-19:15 | MySQL 8.0 の便利機能とSQL標準 | MySQL テクニカルアナリスト 木村明治 氏 |
| 19:30-19:40 | MySQL Binlog のパケットと自作クライアント | 高野周哉 氏 |
| … |
プロシージャの中身のクエリはスロークエリログに落ちない の続き。
Vanilla MySQLだとプロシージャの中身がログに落ちませんが、Percona Server ではスロークエリログが拡張されていて、ログに落ちます。
log_slow_sp_statements
で出力の有無を設定します。デフォルトではプロシージャの中身をスロークエリログに出力する設定になってます。
mysql> SHOW GLOBAL VARIABLES LIKE
'log_slow_sp_statements';
+------------------------+-------+
|
Variable_name
| Value |
+------------------------+-------+
| log_slow_sp_statements | …
プロシージャの中身のクエリはスロークエリログに落ちない の続き。
Vanilla MySQLだとプロシージャの中身がログに落ちませんが、Percona Server
ではスロークエリログが拡張されていて、ログに落ちます。
log_slow_sp_statements
で出力の有無を設定します。デフォルトではプロシージャの中身をスロークエリログに出力する設定になってます。
mysql> SHOW GLOBAL VARIABLES LIKE
'log_slow_sp_statements';
+------------------------+-------+
| …
とあるMySQLのデータベースで、性能劣化した疑いのあるプロシージャがありました。
プロシージャには複数のSELECTやINSERTが含まれています。
どのSQLが遅かったか突き止める方法はあるのでしょうか?
プロシージャに含まれている、各SQLはスロークエリログに落ちるんでしょうか?
試してみます。
テスト用に遅いプロシージャを作ります。
ログを出します。
DELIMITER //
CREATE PROCEDURE sample()
BEGIN
SELECT SLEEP(10);
END
//
DELIMITER ;
mysql> SET GLOBAL slow_query_log = ON;
Query OK, 0 rows affected (0.00 sec)
mysql> SET GLOBAL long_query_time = 0;
Query OK, 0 rows affected (0.00 sec)
…
MySQLのBug Report
もう一週間経ったけど、今回出したバグレポートでドキュメントが修正されました。めでたい。
単にドキュメントが修正されただけですが、せっかくなのでMySQLにBug reportするまでの流れを書いておきます。
アカウント登録
シュッと登録します
How to Report a Bugを読む
なにやら説明がありそうなので、読んでおきます。 なにか厳しい規則があるというわけではないので、チェックリスト的にさらっと読んでからレポートを書くと良さそうです。 …
[さらに読む]