zoukankan      html  css  js  c++  java
  • MySQL优化:使用show status查看MySQL服务器状态信息

    在网站开发过程中,有些时候我们需要了解MySQL的服务器状态信息,譬如当前MySQL启动后的运行时间,当前MySQL的客户端会话连接数,当前MySQL服务器执行的慢查询数,当前MySQL执行了多少SELECT语句、执行了多少UPDATE/DELETE/INSERT语句等统计信息,从而便于我们根据当前MySQL服务器的运行状态进行对应的调整或优化工作。

    在MySQL中,我们可以使用SHOW STATUS指令语句来查看MySQL服务器的状态信息。下面,我们以DOS命令窗口的形式连接MySQL,并执行show status;指令,我们将看到如下显示信息:

    执行show status指令显示的部分结果执行show status指令显示的部分结果

    当我们执行show status语句时,MySQL将会列出多达300多条的状态信息记录,其中包括了供我们查看了解的各种信息。不过,如果直接使用show status指令得到300多条记录,会让我们看得眼花缭乱,因此我们希望能够「按需查看」一部分状态信息。这个时候,我们可以在show status语句后加上对应的like子句。例如,我们想要查看当前MySQL启动后的运行时间,我们可以执行如下语句:

    --查询当前MySQL本次启动后的运行统计时间
    show status like 'uptime';

    此时,我们就可以看到如下结果:

    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | Uptime        | 5667  |
    +---------------+-------+
    1 row in set (0.00 sec)

    同样的,如果我们要本次MySQL启动后执行的SELECT语句的次数,我们可以执行如下语句:

    show status like 'com_select';

    对应输出结果如下:

    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | Com_select    | 1     |
    +---------------+-------+
    1 row in set (0.00 sec)

    此外,与WHERE子句中的LIKE关键字类似,show status后的LIKE关键字也可以使用'_'或'%'等通配符来进行模糊匹配。例如我们可以执行如下语句来查看MySQL服务器的线程信息:

    show status like 'Thread_%';

    对应输出结果如下:

    +-------------------+-------+
    | Variable_name     | Value |
    +-------------------+-------+
    | Threads_cached    | 0     |
    | Threads_connected | 1     |
    | Threads_created   | 1     |
    | Threads_running   | 1     |
    +-------------------+-------+
    4 rows in set (0.00 sec)

    值得注意的是,在上述show status like 'com_select'指令的执行示例中,显示的SELECT语句统计信息仅仅表示当前会话连接执行的SELECT语句数量。因为,show status指令的完整语法如下:

    SHOW [统计范围] STATUS [LIKE '状态项名称']
    --统计范围关键字分为GLOBALSESSION(或LOCAL)两种。

    show status的完整语法中,"[]"中的部分是可选的,如果我们的show status语句中不包含统计范围关键字,则默认统计范围为SESSION,也就是只统计当前连接的状态信息。如果我们需要查询自当前MySQL启动后所有连接执行的SELECT语句总数,我们可以执行如下语句:

    show global status like 'com_select';

    以上即是show status的详细用法。由于show status的状态统计项较多,我们就不再一一解释每个统计项的具体含义,在这里,我们仅列出部分常用的状态信息查看语句:

    
    
    1. --查看MySQL本次启动后的运行时间(单位:秒)
    2. show status like 'uptime';
    3. --查看select语句的执行数
    4. show [global] status like 'com_select';
    5. --查看insert语句的执行数
    6. show [global] status like 'com_insert';
    7. --查看update语句的执行数
    8. show [global] status like 'com_update';
    9. --查看delete语句的执行数
    10. show [global] status like 'com_delete';
    11. --查看试图连接到MySQL(不管是否连接成功)的连接数
    12. show status like 'connections';
    13. --查看线程缓存内的线程的数量。
    14. show status like 'threads_cached';
    15. --查看当前打开的连接的数量。
    16. show status like 'threads_connected';
    17. --查看当前打开的连接的数量。
    18. show status like 'threads_connected';
    19. --查看创建用来处理连接的线程数。如果Threads_created较大,你可能要增加thread_cache_size值。
    20. show status like 'threads_created';
    21. --查看激活的(非睡眠状态)线程数。
    22. show status like 'threads_running';
    23. --查看立即获得的表的锁的次数。
    24. show status like 'table_locks_immediate';
    25. --查看不能立即获得的表的锁的次数。如果该值较高,并且有性能问题,你应首先优化查询,然后拆分表或使用复制。
    26. show status like 'table_locks_waited';
    27. --查看创建时间超过slow_launch_time秒的线程数。
    28. show status like 'slow_launch_threads';
    29. --查看查询时间超过long_query_time秒的查询的个数。
    30. show status like 'slow_queries';
  • 相关阅读:
    LeetCode 1122. Relative Sort Array (数组的相对排序)
    LeetCode 46. Permutations (全排列)
    LeetCode 47. Permutations II (全排列 II)
    LeetCode 77. Combinations (组合)
    LeetCode 1005. Maximize Sum Of Array After K Negations (K 次取反后最大化的数组和)
    LeetCode 922. Sort Array By Parity II (按奇偶排序数组 II)
    LeetCode 1219. Path with Maximum Gold (黄金矿工)
    LeetCode 1029. Two City Scheduling (两地调度)
    LeetCode 392. Is Subsequence (判断子序列)
    写程序判断系统是大端序还是小端序
  • 原文地址:https://www.cnblogs.com/mydriverc/p/8303393.html
Copyright © 2011-2022 走看看