Documentation Home

8.14.1 访问进程列表

下面的讨论列举了进程信息的来源、查看进程信息所需的权限,并描述了进程列表条目的内容。

过程信息来源

过程信息可从以下来源获得:

threads表与 SHOW PROCESSLISTINFORMATION_SCHEMA PROCESSLISTmysqladmin processlist的比较如下:

  • 访问该threads表不需要互斥锁,并且对服务器性能的影响最小。其他来源对性能有负面影响,因为它们需要互斥量。

  • threads表显示了后台线程,而其他来源则没有。它还为每个线程提供其他来源不提供的附加信息,例如线程是前台线程还是后台线程,以及与线程关联的服务器内的位置。这意味着该 threads表可用于监视其他来源无法监视的线程活动。

  • 您可以启用或禁用 Performance Schema 线程监视,如 第 22.12.10.3 节,“线程表”中所述。

由于这些原因,使用其他线程信息源之一执行服务器监视的 DBA 可能希望改为使用该threads表进行监视。

访问进程列表所需的权限

对于大多数进程信息源,如果您有 PROCESS权限,您可以看到所有线程,甚至是属于其他用户的线程。否则(没有PROCESS 特权),非匿名用户可以访问关于他们自己的线程的信息,但不能访问其他用户的线程,而匿名用户则不能访问线程信息。

Performance Schemathreads 表也提供线程信息,但表访问使用不同的权限模型。请参阅 第 22.12.10.3 节,“线程表”

进程列表条目的内容

每个进程列表条目包含几条信息。以下列表使用SHOW PROCESSLIST 输出中的标签描述了它们。其他过程信息源使用类似的标签。

  • Id是与线程关联的客户端的连接标识符。

  • UserHost 指明与线程关联的帐户。

  • db是线程的默认数据库,或者NULL如果未选择任何数据库。

  • CommandState 指出线程正在做什么。

    大多数状态对应于非常快速的操作。如果线程在给定状态下停留数秒,则可能存在需要调查的问题。

    以下部分列出了可能的 Command值,以及 State按类别分组的值。其中一些值的含义是不言而喻的。对于其他人,提供了额外的描述。

    笔记

    检查进程列表信息的应用程序应该知道命令和状态可能会发生变化。

  • Time指示线程处于其当前状态的时间。在某些情况下,线程的当前时间概念可能会改变:线程可以使用 更改时间 。对于副本 SQL 线程,该值是最后一个复制事件的时间戳与副本主机的实际时间之间的秒数。请参阅 第 17.2.1 节,“复制线程”SET TIMESTAMP = value

  • Info指示线程正在执行的语句,或者NULL它是否正在执行任何语句。对于SHOW PROCESSLIST,此值仅包含语句的前 100 个字符。要查看完整的语句,请使用 SHOW FULL PROCESSLIST(或查询不同的过程信息源)。