MySQL の遅いクエリ操作の例の分析 [有効化、テスト、確認など]

MySQL の遅いクエリ操作の例の分析 [有効化、テスト、確認など]

この記事では、MySQL のスロー クエリ操作について例を挙げて説明します。ご参考までに、詳細は以下の通りです。

一部の MySQL SQL ステートメントは非常に遅く実行される可能性があり、サーバーの負荷が急増する可能性があります。

まず、top コマンドや ps コマンドなどを使用して、負荷に影響を与えているのが MySQL であることを確認します。

次に、MySQL に入り、 show full processlistコマンドを使用して実行中の SQL ステートメントを照会し、問題を確認します。explainコマンドを使用してステータスを表示します。

最後に、削除または最適化するSQL文を見つけます

Centos7にmariadbサービスをインストールする

yum -y mariadb-server mariadb-devel をインストールします

低速クエリを有効にする

/etc/my.cnf.d/server.cnf の詳細
[マリアdb]
slow_query_log=オン
slow_query_log_file=/usr/local/mysql/data/slow.log
長いクエリ時間=1

mariadbサービスを開始する

systemctl で mariadb を起動します。

MySQLのスロークエリが有効になっているかどうか、また上記がスロークエリである期間がどのくらいかを確認します。

MariaDB [(なし)]> '%slow_query%' のような変数を表示します。
+---------------------+--------------------------------+
| 変数名 | 値 |
+---------------------+--------------------------------+
| slow_query_log | オン |
| slow_query_log_file | /usr/local/mysql/data/slow.log |
+---------------------+--------------------------------+
セット内の 2 行 (0.00 秒)

MariaDB [(なし)]> 'long_query_time' のような変数を表示します。
+-----------------+----------+
| 変数名 | 値 |
+-----------------+----------+
| 長いクエリ時間 | 1.000000 |
+-----------------+----------+
セット内の 1 行 (0.00 秒)

#スロークエリが有効になっていない場合は、コマンドラインで有効にすることができます。mysql> set global slow_query_log=1;
クエリは正常、影響を受けた行は 0 行 (0.00 秒)

遅いクエリをテストし、ログを表示する

MariaDB [(なし)]> sleep(2) を選択します。
+----------+
| 睡眠(2) |
+----------+
| 0 |
+----------+
セット1列(2.00秒)

[root@localhost ~]# /usr/local/mysql/data/slow.log の詳細
/usr/libexec/mysqld、バージョン: 5.5.60-MariaDB (MariaDB サーバー)。次で開始:
TCP ポート: 0 Unix ソケット: /var/lib/mysql/mysql.sock
時間IDコマンド引数
# 時刻: 180930 23:51:07
# ユーザー@ホスト: root[root] @ localhost []
# Thread_id: 2 スキーマ: QC_hit: いいえ
# クエリ時間: 2.001017 ロック時間: 0.000000 送信行数: 1 検査行数: 0
タイムスタンプを1538322667に設定します。
スリープ(2)を選択します。

遅いクエリの確認

MariaDB [(なし)]> show full processlist; #進行中のスロークエリの状態を表示します +----+------+-----------+---------+----------+-----------+-----------+------------------------+----------+
| ID | ユーザー | ホスト | db | コマンド | 時間 | 状態 | 情報 | 進行状況 |
+----+------+-----------+---------+----------+-----------+-----------+--------------------------+----------+
| 3 | root | localhost | NULL | クエリ | 9 | ユーザースリープ | select sleep(10) | 0.000 |
| 4 | root | localhost | NULL | クエリ | 0 | NULL | 完全なプロセスリストを表示 | 0.000 |
+----+------+-----------+---------+----------+-----------+-----------+--------------------------+----------+
セット内の 2 行 (0.00 秒)

MariaDB [(なし)]> show full processlist; #状態を確認します スロークエリは終了しましたが、ユーザーはログインしています +----+-------+-----------+---------+--------+-------+-------+------------------------+---------+
| ID | ユーザー | ホスト | db | コマンド | 時間 | 状態 | 情報 | 進行状況 |
+----+------+-----------+---------+--------+--------+--------+-------------------------+----------+
| 3 | ルート | ローカルホスト | NULL | スリープ | 1 | | NULL | 0.000 |
| 4 | root | localhost | NULL | クエリ | 0 | NULL | 完全なプロセスリストを表示 | 0.000 |
+----+------+-----------+---------+--------+--------+--------+-------------------------+----------+
セット内の 2 行 (0.00 秒)

MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL クエリ スキル」、「MySQL 共通関数の概要」、「MySQL ログ操作スキル」、「MySQL トランザクション操作スキルの概要」、「MySQL ストアド プロシージャ スキル」、および「MySQL データベース ロック関連スキルの概要」

この記事が皆様のMySQLデータベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • MySQL ストレステストツールの使い方
  • PHP+MySQL でオンラインテストの回答例を実装する
  • MySQL 5.7 に組み込まれているストレス テストの mysqlslap コマンドと構文の詳細な説明
  • MySQLで数千万のテストデータを素早く作成する方法
  • MySQL のメモリ使用量と CPU 使用率が高い場合のテストと解決策
  • sysbench を使用して MySQL のパフォーマンスをテストする詳細なチュートリアル
  • MySQL ループ文 while ループ テスト
  • MySQLデータベースはsysbenchに基づくOLTPベンチマークテストを実装します

<<:  Win10でIIS10を構成し、ASPプログラムのデバッグをサポートする手順

>>:  WeChatアプレットを使用して天井効果を実現する方法の例

推薦する

XHTMLタグは適切に使用する必要があります

<br />123WORDPRESS.COM の以前のチュートリアルでは、Web ページ...

Axios はリクエストをキャンセルし、重複リクエストを回避します

目次起源現状リクエストをキャンセル cancelTokenリクエスト方法の変更重複したリクエストを避...

チャットバブル効果を実現するCSS

1. レンダリングJD効果シミュレーション効果 2. 原則高さと幅が0のボックスを用意しますこのボ...

HTML ページの部分更新の実装コード

イベント応答の更新: 要求されたときのみ更新1. JS HTML DOM または jQuery を介...

ウェブページのテキストデザインは、服を着た賢い女の子のようであるべきだ

<br />「この世に醜い女性はいない、あるのは怠惰な女性だけだ」これは女性の美のバイブ...

MYSQLテーブルの包括的な概要

目次1. テーブルを作成する1.1. テーブルを作成するための基本構文1.1.1. シンプルなテーブ...

Vueにおける仮想DOMの理解のまとめ

これは本質的に、ビュー インターフェース構造を記述するために使用される共通の js オブジェクトです...

Vue のライフサイクルとフック関数の詳細な説明と典型的な面接の質問

目次1. Vue ライフサイクル2. フック機能2.1 4つの段階と8つの方法に分かれています。 2...

mysqlとnavicat間の接続を確立する際の1251エラーを解決する

コンピュータを再インストールし、最新バージョンのMySQLデータベースをインストールしました。その結...

WangEditor リッチ テキスト コンポーネントを Angular でカプセル化する方法

リッチ テキスト コンポーネントは、Web プログラムで、特にブログやフォーラムなどの Web サイ...

JS クロスドメイン ソリューション React 構成 リバース プロキシ

クロスドメインソリューションjsonp (get をシミュレート) CORS (クロスオリジンリソー...

Vue で echarts を使用してコンポーネントを視覚化する方法

echarts コンポーネントの公式ウェブサイト アドレス: https://echarts.apa...

Vue ブラウザログアウトの実装例

目次1. beforeunload イベント2. アンロードイベント3. ソースコードプロジェクトの...

MySQL EXPLAIN ステートメントの使用例

目次1. 使用方法2. 出力結果1.id 2.選択タイプ3.表4.パーティション5.タイプ6.可能な...

XHTML の一般的な構造タグ

構造本文、見出し、HTML、タイトル文章abbr、頭字語、アドレス、引用ブロック、br、引用、コード...