Mais conteúdo relacionado Semelhante a MySQLアーキテクチャ図解講座 (20) Mais de Mikiya Okuno (15) MySQLアーキテクチャ図解講座3. 自己紹介
●
MySQL サポートエンジニア
– 日々のしごと
● トラブルシューティング全般
● Q&A 回答
●
パフォーマンスチューニング
など
●
ライフワーク
– 自由なソフトウェアの普及
● オープンソースではない
● GPL 万歳!!
– 最近はまってる趣味はリカンベント(自転車)
●
ブログ
– 漢のコンピュータ道
– http://nippondanji.blogspot.com/
9. クエリ実行の流れ
● GNU Bison によるパーサー
● コストベースオプティマイザ
– コスト係数を調整可能
– ストレージエンジンから
統計情報を取得
● 行アクセスやトランザクション管
理はストレージエンジンまかせ
10. Nested Loop Join
SELECT … FROM t1 INNER JOIN t2 ON … WHERE …
for each row in t1 matching where condition {
for each row in t2 matching join and where condition {
send joined row to client
}
}
16. InnoDB の分離レベル
分離レベル 分離性 ダーティー
リード
インコンシス
テントリード
ロストアップ
デート
ファントム
READ-
UNCOMMITTED
低 ○ ○ ○ ○
READ-
COMMITTED
× ○ ○ ○
REPEATABLE-
READ
× × ○ ×
SERIALIZABLE 高 × × × ×
●
InnoDB の RR ではファントムは起きない!!
– ただしロッキングリードとノンロッキングリードに注意
19. UNDO ログトランケート
UNDO ログ空き領域
UNDO ログ使用中の領域
innodb_max_
undo_log_size
INACTIVE
初期サイズ = 10MB
INACTIVE にして
空になるまで待つ。
その間は他の UNDO
ログファイルで凌ぐ。
UNDO ログ
ファイルを初期化
UNDO ログファイルの
サイズがしきい値を超えた
20. 圧縮テーブル
● innodb_file_format = Barracuda
● CREATE TABLE tblname (…) ENGINE = InnoDB ROW_FORMAT =
COMPRESSED KEY_BLOCK_SIZE=4;
バッファプールが
二重に消費される。
オーバーヘッド大。
30. パフォーマンススキーマ
vs 情報スキーマ
パフォーマンススキーマ 情報スキーマ
主目的 パフォーマンスデータの取得 メタデータの取得
アプリケーション パフォーマンスチューニング 監視ツールや管理ツール
導入されたバージョン 5.5 5.1
SQL 標準? いいえ はい
実装方法 ストレージエンジンのひとつ 情報スキーマ API
データ収集のタイミング mysqld 内部で任意のタイミ
ングでコード実行時
情報スキーマテーブルアクセ
ス時
通常時のオーバーヘッド あり なし
表示によるオーバーヘッド 少ない 大きい
類似のツール DTrace, SystemTap SHOW コマンド
33. 宣伝: 新書籍「詳解 MySQL 5.7 」
● MySQL 5.7 の新機能を網羅
– 175 もの新機能を解説
– 新機能の理解に欠かせ
ないアーキテクチャの話
も盛りだくさん
– 本日解説しなかった新
機能も詳しく解説!!
●
8 月 23 日発売予定