常见的mysql 进程state

2024-08-28 06:08

本文主要是介绍常见的mysql 进程state,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自http://blog.itpub.net/22664653/viewspace-754715/

Analyzing
线程是对MyISAM 表的统计信息做分析(例如, ANALYZE TABLE )。
----------------------------------------------------------------------------
checking permissions
线程是检查服务器是否具有所需的权限来执行该语句。
----------------------------------------------------------------------------
Checking table
线程正在执行表检查操作。
----------------------------------------------------------------------------
cleaning up
线程处理一个命令,并正准备以释放内存和重置某些状态变量。
----------------------------------------------------------------------------
closing tables
线程是改变表中的数据刷新到磁盘和关闭使用的表。 这应该是一个快速的操作。 如果没有,你应该确认你没有一个完整的磁盘和磁盘是不是在十分繁重的情况下使用。
------------------------------------------------------------------------
converting HEAP to MyISAM
线程是从转换内部临时表MEMORY内存表磁盘MyISAM表。
----------------------------------------------------------------------
copy to tmp table
线程正在处理一个ALTER TABLE语句。 这种状态发生后,与新结构的表已创建,但前行复制到它。
--------------------------------------------------------------------------------
Copying to group table
如果语句有不同的ORDER BY和GROUP BY标准,按组排序的行复制到一个临时表。
----------------------------------------------------------------------------
Copying to tmp table
服务器复制到内存中的临时表。
--------------------------------------------------------------------
Copying to tmp table on disk
服务器复制到一个临时表在磁盘上。 临时结果集已经变得过于庞大(见7.8.4节,“MySQL如何使用内部临时表” )。 因此,线程从内存中的临时表基于磁盘的格式,以节省内存。
--------------------------------------------------------------------------------
Creating index
线程正在处理ALTER TABLE ... ENABLE KEYS ALTER TABLE ... ENABLE KEYS为MyISAM MyISAM表。
----------------------------------------------------------------
Creating sort index
mysql 要通过内部临时表的方案来处理这次Select,当然这个表是内存中的。当内存放不下时,全部copy到磁盘。有可能导致性能极具下降。
---------------------------------------------------------
creating table
线程创建一个表。 这包括建立临时表。
-----------------------------------
Creating tmp table
线程是创建一个临时表在内存或磁盘上。 如果表是在内存中创建,但后来被转换成一个磁盘上的表,在该操作的Copying to tmp table on disk在磁盘上。
---------------------------------------------------------
deleting from main table
服务器正在执行多表删除的第一部分。 它只能从第一个表中删除,并保存列和删除从其他表(参考)偏移。
---------------------------------------------------------------
deleting from reference tables
服务器正在执行多表删除的第二部分,从其他表中删除匹配的行。
------------------------------------------------------------
discard_or_import_tablespace
线程正在处理一个ALTER TABLE ... DISCARD TABLESPACE ALTER TABLE ... DISCARD TABLESPACE或ALTER TABLE ... IMPORT TABLESPACE ALTER TABLE ... IMPORT TABLESPACE语句。
-----------------------------------
end
清理ALTER TABLE , CREATE VIEW , DELETE , INSERT , SELECT或UPDATE语句。
---------------------------------------
executing
线程已开始执行语句。
------------------------------
Execution of init_command
线程正在执行中的价值陈述init_command系统变量。
----------------------------------------------
freeing items
线程已执行的命令。 释放一些在这种状态下完成的项目,涉及的查询缓存。 这种状态通常后跟cleaning up 。
------------------------------------------------
Flushing tables
线程正在执行FLUSH TABLES ,等待所有线程关闭其表。
-------------------------------
FULLTEXT initialization
该服务器是准备执行一个自然语言的全文检索。
---------------------------------------
init
这发生之前的初始化ALTER TABLE , DELETE , INSERT , SELECT或UPDATE语句。 服务器在这种状态下采取的行动包括冲洗二进制日志中InnoDB日志,和一些查询缓存清理操作。
对于end状态,以下操作可能会发生的事情:
更改后删除表中的数据查询的缓存条目
二进制日志中写一个事件
释放内存缓冲区,包括为斑点
--------------------------
Killed
有人发送一个KILL线程的语句,它应该中止在下一次检查杀死标志。 检查该标志是在每个MySQL中的主要循环,但在某些情况下可能还需要很短的时间为线程死亡。 如果线程是由其他线程锁定,杀死尽快生效的其他线程释放它的锁。
-----------
Locked
查询被锁定由另一个查询。
-------------------------
logging slow query
线程正在写一慢查询日志的语句。
NULL
这种状态是用于SHOW PROCESSLIST状态。
----------------------
login
连接线程的初始状态,直到客户端已成功通过身份验证。
---------------------------------------------
Opening tables , Opening table
线程试图打开一个表。 这应该是非常快的过程中,除非有阻止打开。 例如,一个ALTER TABLE或LOCK TABLE语句可以防止打开一个表的语句,直到完成。 您的table_cache值足够大,这也是值得一试。
----------------------------------------------------
optimizing
服务器执行查询的初始优化。
--------------------------------
preparing
这种状态出现在查询优化过程中。

-------------------------
Purging old relay logs
线程是消除不必要的中继日志文件。
---------------------------
query end
这种状态发生后处理查询,但在此freeing items的项目状态。
----------------------
Reading from net
服务器是阅读从网络数据包。
---------------------
Removing duplicates
查询使用SELECT DISTINCT在这样一种方式是MySQL不能优化掉在早期阶段的不同操作。 正因为如此,MySQL需要一个额外的的阶段,将结果发送到客户端之前删除所有重复行。
---------------------------
removing tmp table
线程是消除处理后,内部的SELECT表SELECT语句。 如果没有创建临时表,这种状态是不使用。
---------------------
rename
线程重命名表。
-----------------------
rename result table
线程正在处理一个ALTER TABLE语句,创建新表,并重新命名它来取代原来的表。
-----------------
Reopen tables
线程有一个表锁,但注意到后锁底层表结构改变。 它释放的锁,关闭表,并试图重新打开它。
------------------
Repair by sorting
修复代码是使用排序创建索引。
-------------------
Repair done
该线程已完成了一个多线程的MyISAM表。
-------------------
Repair with keycache
修复代码是使用创建密钥通过关键缓存。 这是远远高于速度Repair by sorting进行排序。
---------------
Rolling back
线程回滚事务。
------------
Saving state
如修理或分析MyISAM MyISAM表操作,线程是节能的新表的状态.MYI文件头。 国家包括行数,如信息AUTO_INCREMENT计数器,以及关键的分布。
--------------------------
Searching rows for update
线程正在做第一阶段前更新他们找到所有匹配的行。 这工作要做, UPDATE UPDATE正在改变,是用来寻找所涉及的行的索引。
------------------
Sending data
线程处理一个SELECT语句行,将数据发送到客户端。 因为在这个状态发生的操作往往执行大量的磁盘访问(读取),它往往是在一个给定的查询的生命周期最长的运行状态。
-----------
setup
线程开始一个ALTER TABLE操作。
---------------------
Sorting for group
线程是做一个分类,以GROUP BY集团。
---------------
Sorting for order
线程是做来满足ORDER BY排序。
-------------------
Sorting index
线程排序索引的网页,更高效的访问MyISAM表的优化操作。
------------------
Sorting result
对于SELECT语句,这是Creating sort index类似,但nontemporary表。
-----------------
statistics
服务器计算统计数据,以制定一个查询执行计划。 如果一个线程处于这种状态很长一段时间,服务器可能是磁盘绑定执行其他工作。
------------------
System lock
该线程将要求或正在等待内部或外部的系统锁表。 如果这种状态是造成外部锁的请求和您不使用多个mysqld的访问相同的MyISAM MyISAM表,你可以禁用与外部系统--skip-external-locking锁定选项。 然而,外部锁定是默认禁用的,所以这个选项很可能不会有任何效果。 SHOW PROFILE ,这种状态意味着线程请求锁(不等待)。
-------------
Table lock
后的下一个线程状态System lock锁定。 线程已经收购了外部锁定,并要求内部表锁。
-------------
Updating
线程正在寻找要更新的行和更新他们。
---------------------
updating main table
服务器正在执行多表更新的第一部分。 它是只更新第一个表,并节省列和用于更新其他表(参考)偏移。
---------------------------
updating reference tables
服务器正在执行多表更新的第二部分和更新从其他表匹配的行。
--------------------
User lock
线程请求或要求与咨询锁等待GET_LOCK()调用。 SHOW PROFILE ,这种状态意味着线程请求锁(不等待)。
-------------
Waiting for release of readlock
线程正在等待另一个线程(与获得全局读锁FLUSH TABLES WITH READ LOCK TABLES)被释放。
----------------------------------------
Waiting for tables , Waiting for table
线程得到一个表的基本结构发生了变化的通知,它需要重新打开表,以获取新的结构。 然而,重新打开表,它必须等到所有其他线程已经关闭了表中的问题。
此通知发生,如果另一个线程已FLUSH TABLES或桌子上的问题下面的语句之一FLUSH TABLES tbl_name tbl_name ALTER TABLE , RENAME TABLE TABLE REPAIR TABLE TABLE ANALYZE TABLE TABLE, OPTIMIZE TABLE TABLE 。
-----------------------
Waiting on cond
在该线程正在等待一个条件,成为真正的一般状态。 没有特定的状态信息是可用的。
-----------------------------
Waiting to get readlock
线程已发出一个FLUSH TABLES WITH READ LOCK语句获得全局读锁,并正在等待获取锁。
---------------------
Writing to net
服务器写一个数据包到网络上。
----------------------------------------------------------------------------
----------------------------------------------------------------------------

这篇关于常见的mysql 进程state的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113941

相关文章

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

Java 连接Sql sever 2008

Java 连接Sql sever 2008 /Sql sever 2008 R2 import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class TestJDBC