- 浏览: 160834 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (118)
- rest (2)
- spring (8)
- java proxy (1)
- linux (9)
- nginx (1)
- 加密算法 (2)
- jquery (3)
- hibernate (9)
- bootstrap (0)
- mysql (15)
- java (6)
- 应用服务器 (2)
- jdbc (3)
- js (3)
- springMVC (3)
- JAVA基础分类 (2)
- mycat (5)
- mybatis (0)
- drools规则引擎 (0)
- 压力测试工具 (1)
- 日志管理 (3)
- maven (3)
- 数据源 (1)
- kryo 序列化 (1)
- dubbo (3)
- com.google.common.collect 工具类 (2)
- memcache (2)
- jdk (1)
- 正则 (2)
- amoeba (1)
- 分布式事务 (2)
- html5 (1)
- spring-data-elasticSearch (2)
- shell脚本 (1)
- Elasticsearch (9)
- 设计模式 (2)
- NOSQL (1)
- hash算法 (4)
- 多线程 (0)
- 电商 (1)
- pinpoint (0)
最新评论
After create
This occurs when the thread creates a table (including internal temporary tables), at the end of the function that creates the table. This state is used even if the table could not be created due to some error.
这个状态当线程创建一个表(包括内部临时表)时,在这个建表功能结束时出现。即使某些错误导致建表失败,也会使用这个状态。
Analyzing
The thread is calculating a MyISAM table key distributions (for example, for ANALYZE TABLE).
当计算MyISAM表索引分布时。(比如进行ANALYZE TABLE时)
checking permissions
The thread is checking whether the server has the required privileges to execute the statement.
这个线程检查服务器是否有具有执行该语句的所需权限。
Checking table
The thread is performing a table check operation.
线程正在执行表检查操作。
cleaning up
The thread has processed one command and is preparing to free memory and reset certain state variables.
线程处理一个命令,并正准备释放内存和重置某些状态变量。
closing tables
The thread is flushing the changed table data to disk and closing the used tables. This should be a fast operation. If not, verify that you do not have a full disk and that the disk is not in very heavy use.
线程正在将变更的表中的数据刷新到磁盘上并正在关闭使用过的表。这应该是一个快速的操作。如果不快,则应该检查硬盘空间是否已满或者硬盘IO是否达到瓶颈。
converting HEAP to MyISAM
The thread is converting an internal temporary table from a MEMORY table to an on-disk MyISAM table.
线程将一个内部临时表转换为磁盘上的MyISAM表。
copy to tmp table
The thread is processing an ALTER TABLE statement. This state occurs after the table with the new structure has been created but before rows are copied into it.
线程正在处理一个ALTER TABLE语句。这个状态发生在新的表结构已经创建之后,但是在数据被复制进入之前。
Copying to group table
If a statement has different ORDER BY and GROUP BY criteria, the rows are sorted by group and copied to a temporary table.
如果一个语句有不同的ORDER BY和GROUP BY条件,数据会被复制到一个临时表中并且按组排序。
Copying to tmp table
The server is copying to a temporary table in memory.
线程将数据写入内存中的临时表。
Copying to tmp table on disk
The server is copying to a temporary table on disk. The temporary result set has become too large (see Section 8.4.3.3, “How MySQL Uses Internal Temporary Tables”). Consequently, the thread is changing the temporary table from in-memory to diskbased format to save memory.
线程正在将数据写入磁盘中的临时表。临时表的结果集过大(大于tmp_table_size)。所以,线程将临时表由基于内存模式改为基于磁盘模式,以节省内存。
Creating index
The thread is processing ALTER TABLE ... ENABLE KEYS for a MyISAM table.
线程正在对一个MyISAM表执行ALTER TABLE ... ENABLE KEYS语句。
Creating sort index
The thread is processing a SELECT that is resolved using an internal temporary table.
线程正在使用内部临时表处理一个SELECT 操作。
creating table
The thread is creating a table. This includes creation of temporary tables.
线程正在创建一个表,包括创建临时表。
Creating tmp table
The thread is creating a temporary table in memory or on disk. If the table is created in memory but later is converted to an ondisk table, the state during that operation will be Copying to tmp table on disk.
线程正在创建一个临时表在内存或者磁盘上。如果这个表创建在内存上但是之后被转换到磁盘上,这个状态在运行Copying to tmp table on disk 的时候保持。
deleting from main table
The server is executing the first part of a multiple-table delete. It is deleting only from the first table, and saving columns and offsets to be used for deleting from the other (reference) tables.
线程正在执行多表删除的第一部分,只从第一个表中删除。并且保存列和偏移量用来从其他(参考)表删除。
deleting from reference tables
The server is executing the second part of a multiple-table delete and deleting the matched rows from the other tables.
线程正在执行多表删除的第二部分,并从其他表中删除匹配的行。
discard_or_import_tablespace
The thread is processing an ALTER TABLE ... DISCARD TABLESPACE or ALTER TABLE ... IMPORT TABLESPACE statement.
线程正在执行ALTER TABLE ... DISCARD TABLESPACE 或 ALTER TABLE ... IMPORT TABLESPACE语句。
end
This occurs at the end but before the cleanup of ALTER TABLE, CREATE VIEW, DELETE, INSERT, SELECT, or UPDATE statements.
这个状态出现在结束时,但是在对ALTER TABLE, CREATE VIEW, DELETE, INSERT, SELECT, 或者 UPDATE 语句进行清理之前。
executing
The thread has begun executing a statement.
该线程已开始执行一条语句。
Execution of init_command
The thread is executing statements in the value of the init_command system variable.
线程正在执行处于init_command系统变量的值中的语句。
freeing items
The thread has executed a command. Some freeing of items done during this state involves the query cache. This state is usually followed by cleaning up.
线程已经执行了命令。在这个状态中涉及的查询缓存可以得到一些释放。这个状态通常后面跟随cleaning up状态。
Flushing tables
The thread is executing FLUSH TABLES and is waiting for all threads to close their tables.
线程正在执行FLUSH TABLES 并且等待所有线程关闭他们的表。
FULLTEXT initialization
The server is preparing to perform a natural-language full-text search.
服务器正在准备进行自然语言全文检索。
init
This occurs before the initialization of ALTER TABLE, DELETE, INSERT, SELECT, or UPDATE statements. Actions taken by the server in this state include flushing the binary log, the InnoDB log, and some query cache cleanup operations.
For the end state, the following operations could be happening:
• Removing query cache entries after data in a table is changed
• Writing an event to the binary log
• Freeing memory buffers, including for blobs
这个状态出现在线程初始化ALTER TABLE, DELETE, INSERT, SELECT, 或 UPDATE语句之前。服务器在这种状态下进行的操作,包括:刷新全日志、Innodb日志,和一些查询缓存清理操作。
对于end状态,可能会发生下列操作:
在表中的数据变更之后移除查询缓存。
将事务写入全日志。
释放内存缓冲区,包括大的二进制数据块。
Killed
Someone has sent a KILL statement to the thread and it should abort next time it checks the kill flag. The flag is checked in each major loop in MySQL, but in some cases it might still take a short time for the thread to die. If the thread is locked by some other thread, the kill takes effect as soon as the other thread releases its lock.
程序对线程发送了KILL语句,并且它应该放弃下一次对KILL标记的检查。这个标记在每一个MySQL的主要循环中被检查,但在某些情况下,它可能需要令线程在很短的时间内死亡。如果这个线程被其他线程锁住了,这个KILL操作会在其他线程释放锁的瞬时执行。
Locked
The query is locked by another query.
As of MySQL 5.5.3, this state was removed because it was equivalent to the Table lock state and no longer appears in SHOW PROCESSLIST output.
这个查询被其他查询锁住了。
在MySQL 5.5.3版本,这个状态被移除了。因为它相当于表锁状态,并且不再出现在SHOW PROCESSLIST输出中。
logging slow query
The thread is writing a statement to the slow-query log.
这个线程正在将语句写入慢查询日志。
NULL
This state is used for the SHOW PROCESSLIST state.
没有操作的状态。
login
The initial state for a connection thread until the client has been authenticated successfully.
线程连接的初始状态。直到客户端已经成功验证。
manage keys
The server is enabling or disabling a table index.
服务器启用或禁用表索引。
Opening tables, Opening table
The thread is trying to open a table. This is should be very fast procedure, unless something prevents opening. For example, an ALTER TABLE or a LOCK TABLE statement can prevent opening a table until the statement is finished. It is also worth checking that your table_open_cache value is large enough.
线程正试图打开一张表。这应该是非常快的过程,除非打开受到阻止。一个ALTER TABLE 或LOCK TABLE语句能够阻止打开一张表直到语句运行结束。有必要检查table_open_cache的值是否足够大。
optimizing
The server is performing initial optimizations for a query.
服务器执行查询的初步优化。
preparing
This state occurs during query optimization.
在查询优化过程中出现这个状态。
Purging old relay logs
The thread is removing unneeded relay log files.
线程正在移除不必要的中继日志文件。
query end
This state occurs after processing a query but before the freeing items state.
这个状态出现在处理一个查询之后,但是在freeing items状态之前。
Reading from net
The server is reading a packet from the network.
服务器正在从网络阅读数据包。
Removing duplicates
The query was using SELECT DISTINCT in such a way that MySQL could not optimize away the distinct operation at an early stage. Because of this, MySQL requires an extra stage to remove all duplicated rows before sending the result to the client.
查询正在使用SELECT DISTINCT,这种情况下MySQL不能在早期阶段优化掉一些distinct操作。因此,MySQL需要一个额外的阶段,在将结果发送到客户端之前删除所有重复的行。
removing tmp table
The thread is removing an internal temporary table after processing a SELECT statement. This state is not used if no temporary table was created.
线程正在移除一个内置临时表,在执行一条SELECT语句之后。 如果没有临时表产生,那么这个状态不被使用。
rename
The thread is renaming a table.
线程正在重命名一张表。
rename result table
The thread is processing an ALTER TABLE statement, has created the new table, and is renaming it to replace the original table.
线程正在处理ALTER TABLE语句,创建新的表,并且重命名它来代替原有的表。
Reopen tables
The thread got a lock for the table, but noticed after getting the lock that the underlying table structure changed. It has freed the lock, closed the table, and is trying to reopen it.
线程获得了表锁,但是在取得表锁之后才发现该表的底层结构已经发生了变化。线程释放这个锁,关闭表,并试图重新打开该表。
Repair by sorting
The repair code is using a sort to create indexes.
修复代码正在使用一个分类来创建索引。
Repair done
The thread has completed a multi-threaded repair for a MyISAM table.
线程完成一个多线程的MyISAM表的修复。
Repair with keycache
The repair code is using creating keys one by one through the key cache. This is much slower than Repair by sorting.
修复代码正在通过索引缓存一个接一个地使用创建索引。这比通过分类修复要慢很多。
Rolling back
The thread is rolling back a transaction.
线程正在回滚一个事务
Saving state
For MyISAM table operations such as repair or analysis, the thread is saving the new table state to the .MYI file header. State includes information such as number of rows, the AUTO_INCREMENT counter, and key distributions.
对于MyISAM表的类似repair或analysis操作,线程在.MYI文件的头部保存一个新表的状态。状态信息包括行数、自增数、索引分布等等。
Searching rows for update
The thread is doing a first phase to find all matching rows before updating them. This has to be done if the UPDATE is changing the index that is used to find the involved rows.
线程正在进行第一阶段,在更新前寻找所有匹配的行。如果update正在更改用于查找相关行的索引,则必须这么做。
Sending data
The thread is reading and processing rows for a SELECT statement, and sending data to the client. Because operations occurring during this this state tend to perform large amounts of disk access (reads), it is often the longest-running state over the lifetime of a given query.
线程正在读取和处理一条SELECT语句的行,并且将数据发送至客户端。由于在此期间会执行大量的磁盘访问(读操作),这个状态在一个指定查询的生命周期中经常是耗时最长的。
setup
The thread is beginning an ALTER TABLE operation.
线程正开始进行一个ALTER TABLE操作。
Sorting for group
The thread is doing a sort to satisfy a GROUP BY.
线程正在执行一个由GROUP BY指定的排序。
Sorting for order
The thread is doing a sort to satisfy a ORDER BY.
线程正在执行一个由ORDER BY指定的排序。
Sorting index
The thread is sorting index pages for more efficient access during a MyISAM table optimization operation.
线程正在对索引页进行排序,为了对MyISAM表进行操作时获得更优的性能。
Sorting result
For a SELECT statement, this is similar to Creating sort index, but for nontemporary tables.
对于一个SELECT语句,这与创建排序索引相似,但是是对非临时表。
statistics
The server is calculating statistics to develop a query execution plan. If a thread is in this state for a long time, the server is probably disk-bound performing other work.
服务器计算统计去规划一个查询。如果一个线程长时间处于这个状态,这个服务器的磁盘可能在执行其他工作。
System lock
The thread is going to request or is waiting for an internal or external system lock for the table. If this state is being caused by requests for external locks and you are not using multiple mysqld servers that are accessing the same MyISAM tables, you can disable external system locks with the --skip-external-locking option. However, external locking is disabled by default, so it is likely that this option will have no effect. For SHOW PROFILE, this state means the thread is requesting the lock
(not waiting for it).
这个线程正在请求或者等待一个内部的或外部的系统表锁。如果这个状态是由于外部锁的请求产生的,并且你没有使用多个正在访问相同的表的mysqld服务器,那么你可以使用--skip-external-locking选项禁用外部系统锁。然而,外部系统锁默认情况下禁用,因此这个选项可能不会产生效果。对于SHOW PROFILE,这个状态意味着线程正在请求锁。(而非等待)
Table lock
The next thread state after System lock. The thread has acquired an external lock and is going to request an internal table lock.
This state was replaced in MySQL 5.5.6 with Waiting for table level lock.
系统锁定后的下一个线程状态。线程已获得外部锁并且将请求内部表锁。
这个状态在MySQL 5.5.6版本中被Waiting for table level lock取代。
Updating
The thread is searching for rows to update and is updating them.
线程寻找更新匹配的行并进行更新。
updating main table
The server is executing the first part of a multiple-table update. It is updating only the first table, and saving columns and offsets to be used for updating the other (reference) tables.
线程正在执行多表更新的第一部分,只从第一个表中更新。并且保存列和偏移量用来从其他(参考)表更新。
updating reference tables
The server is executing the second part of a multiple-table update and updating the matched rows from the other tables.
线程正在执行多表更新的第二部分,并从其他表中更新匹配的行。
User lock
The thread is going to request or is waiting for an advisory lock requested with a GET_LOCK() call. For SHOW PROFILE, this state means the thread is requesting the lock (not waiting for it).
线程正在请求或等待一个GET_LOCK()调用所要求的咨询锁。对于SHOW PROFILE,这个状态意味这线程正在请求锁。(而非等待)
User sleep
The thread has invoked a SLEEP() call.
线程调用了一个SLEEP()。
Waiting for all running commits to finish
A statement that causes an explicit or implicit commit is waiting for release of a read lock. This state was removed in MySQL 5.5.8; Waiting for commit lock is used instead.
一个显式或隐式语句在提交时等待释放读锁。这个状态在MySQL 5.5.8版本中被移除,以Waiting for commit lock代替。
Waiting for commit lock
A statement that causes an explicit or implicit commit is waiting for release of a read lock or FLUSH TABLES WITH READ LOCK) is waiting for a commit lock. This state was added in MySQL 5.5.8.
同上,这个状态于MySQL 5.5.8版本加入。
Waiting for global read lock
FLUSH TABLES WITH READ LOCK) is waiting for a global read lock.
等待全局读锁。
Waiting for release of readlock
The thread is waiting for a global read lock obtained by another thread (with FLUSH TABLES WITH READ LOCK) to be released.This state was removed in MySQL 5.5.8; Waiting for global read lock or Waiting for commit lock are used instead.
等待释放读锁。
Waiting for tables, Waiting for table, Waiting for table flush
The thread got a notification that the underlying structure for a table has changed and it needs to reopen the table to get the new structure. However, to reopen the table, it must wait until all other threads have closed the table in question.
This notification takes place if another thread has used FLUSH TABLES or one of the following statements on the table in question: FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE, or OPTIMIZE TABLE.
In MySQL 5.5.6, Waiting for table was replaced with Waiting for table flush.
线程获得一个通知,底层表结构已经发生变化,它需要重新打开表来获取新的结构。然而,重新打开表,它必须等到所有其他线程关闭这个有问题的表。
这个通知产生通常因为另一个线程对问题表执行了FLUSH TABLES或者以下语句之一:FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE, or OPTIMIZE TABLE.
Waiting for lock_type lock
The server is waiting to acquire a lock, where lock_type indicates the type of lock:
• Waiting for event metadata lock (added in MySQL 5.5.8)
• Waiting for global metadata lock (replaced by Waiting for global read lock in MySQL 5.5.8)
• Waiting for global read lock (added in MySQL 5.5.8)
• Waiting for schema metadata lock
• Waiting for stored function metadata lock
• Waiting for stored procedure metadata lock
• Waiting for table level lock
• Waiting for table metadata lock
• Waiting for trigger metadata lock (added in MySQL 5.5.8)
等待各个种类的表锁。
Waiting on cond
A generic state in which the thread is waiting for a condition to become true. No specific state information is available.
一个普通的状态,线程正在等待一个条件为真。没有特定的状态信息可用。
Waiting to get readlock
The thread has issued a FLUSH TABLES WITH READ LOCK statement to obtain a global read lock and is waiting to obtain the lock. This state was removed in MySQL 5.5.8; Waiting for global read lock is used instead.
线程发出了一个FLUSH TABLES WITH READ LOCK语句来获取一个全局读锁,并且等待获得这个锁。这个状态在MySQL 5.5.8被移除,使用Waiting for global read lock 来代替。
Writing to net
The server is writing a packet to the network.
服务器正在写一个网络数据包。
This occurs when the thread creates a table (including internal temporary tables), at the end of the function that creates the table. This state is used even if the table could not be created due to some error.
这个状态当线程创建一个表(包括内部临时表)时,在这个建表功能结束时出现。即使某些错误导致建表失败,也会使用这个状态。
Analyzing
The thread is calculating a MyISAM table key distributions (for example, for ANALYZE TABLE).
当计算MyISAM表索引分布时。(比如进行ANALYZE TABLE时)
checking permissions
The thread is checking whether the server has the required privileges to execute the statement.
这个线程检查服务器是否有具有执行该语句的所需权限。
Checking table
The thread is performing a table check operation.
线程正在执行表检查操作。
cleaning up
The thread has processed one command and is preparing to free memory and reset certain state variables.
线程处理一个命令,并正准备释放内存和重置某些状态变量。
closing tables
The thread is flushing the changed table data to disk and closing the used tables. This should be a fast operation. If not, verify that you do not have a full disk and that the disk is not in very heavy use.
线程正在将变更的表中的数据刷新到磁盘上并正在关闭使用过的表。这应该是一个快速的操作。如果不快,则应该检查硬盘空间是否已满或者硬盘IO是否达到瓶颈。
converting HEAP to MyISAM
The thread is converting an internal temporary table from a MEMORY table to an on-disk MyISAM table.
线程将一个内部临时表转换为磁盘上的MyISAM表。
copy to tmp table
The thread is processing an ALTER TABLE statement. This state occurs after the table with the new structure has been created but before rows are copied into it.
线程正在处理一个ALTER TABLE语句。这个状态发生在新的表结构已经创建之后,但是在数据被复制进入之前。
Copying to group table
If a statement has different ORDER BY and GROUP BY criteria, the rows are sorted by group and copied to a temporary table.
如果一个语句有不同的ORDER BY和GROUP BY条件,数据会被复制到一个临时表中并且按组排序。
Copying to tmp table
The server is copying to a temporary table in memory.
线程将数据写入内存中的临时表。
Copying to tmp table on disk
The server is copying to a temporary table on disk. The temporary result set has become too large (see Section 8.4.3.3, “How MySQL Uses Internal Temporary Tables”). Consequently, the thread is changing the temporary table from in-memory to diskbased format to save memory.
线程正在将数据写入磁盘中的临时表。临时表的结果集过大(大于tmp_table_size)。所以,线程将临时表由基于内存模式改为基于磁盘模式,以节省内存。
Creating index
The thread is processing ALTER TABLE ... ENABLE KEYS for a MyISAM table.
线程正在对一个MyISAM表执行ALTER TABLE ... ENABLE KEYS语句。
Creating sort index
The thread is processing a SELECT that is resolved using an internal temporary table.
线程正在使用内部临时表处理一个SELECT 操作。
creating table
The thread is creating a table. This includes creation of temporary tables.
线程正在创建一个表,包括创建临时表。
Creating tmp table
The thread is creating a temporary table in memory or on disk. If the table is created in memory but later is converted to an ondisk table, the state during that operation will be Copying to tmp table on disk.
线程正在创建一个临时表在内存或者磁盘上。如果这个表创建在内存上但是之后被转换到磁盘上,这个状态在运行Copying to tmp table on disk 的时候保持。
deleting from main table
The server is executing the first part of a multiple-table delete. It is deleting only from the first table, and saving columns and offsets to be used for deleting from the other (reference) tables.
线程正在执行多表删除的第一部分,只从第一个表中删除。并且保存列和偏移量用来从其他(参考)表删除。
deleting from reference tables
The server is executing the second part of a multiple-table delete and deleting the matched rows from the other tables.
线程正在执行多表删除的第二部分,并从其他表中删除匹配的行。
discard_or_import_tablespace
The thread is processing an ALTER TABLE ... DISCARD TABLESPACE or ALTER TABLE ... IMPORT TABLESPACE statement.
线程正在执行ALTER TABLE ... DISCARD TABLESPACE 或 ALTER TABLE ... IMPORT TABLESPACE语句。
end
This occurs at the end but before the cleanup of ALTER TABLE, CREATE VIEW, DELETE, INSERT, SELECT, or UPDATE statements.
这个状态出现在结束时,但是在对ALTER TABLE, CREATE VIEW, DELETE, INSERT, SELECT, 或者 UPDATE 语句进行清理之前。
executing
The thread has begun executing a statement.
该线程已开始执行一条语句。
Execution of init_command
The thread is executing statements in the value of the init_command system variable.
线程正在执行处于init_command系统变量的值中的语句。
freeing items
The thread has executed a command. Some freeing of items done during this state involves the query cache. This state is usually followed by cleaning up.
线程已经执行了命令。在这个状态中涉及的查询缓存可以得到一些释放。这个状态通常后面跟随cleaning up状态。
Flushing tables
The thread is executing FLUSH TABLES and is waiting for all threads to close their tables.
线程正在执行FLUSH TABLES 并且等待所有线程关闭他们的表。
FULLTEXT initialization
The server is preparing to perform a natural-language full-text search.
服务器正在准备进行自然语言全文检索。
init
This occurs before the initialization of ALTER TABLE, DELETE, INSERT, SELECT, or UPDATE statements. Actions taken by the server in this state include flushing the binary log, the InnoDB log, and some query cache cleanup operations.
For the end state, the following operations could be happening:
• Removing query cache entries after data in a table is changed
• Writing an event to the binary log
• Freeing memory buffers, including for blobs
这个状态出现在线程初始化ALTER TABLE, DELETE, INSERT, SELECT, 或 UPDATE语句之前。服务器在这种状态下进行的操作,包括:刷新全日志、Innodb日志,和一些查询缓存清理操作。
对于end状态,可能会发生下列操作:
在表中的数据变更之后移除查询缓存。
将事务写入全日志。
释放内存缓冲区,包括大的二进制数据块。
Killed
Someone has sent a KILL statement to the thread and it should abort next time it checks the kill flag. The flag is checked in each major loop in MySQL, but in some cases it might still take a short time for the thread to die. If the thread is locked by some other thread, the kill takes effect as soon as the other thread releases its lock.
程序对线程发送了KILL语句,并且它应该放弃下一次对KILL标记的检查。这个标记在每一个MySQL的主要循环中被检查,但在某些情况下,它可能需要令线程在很短的时间内死亡。如果这个线程被其他线程锁住了,这个KILL操作会在其他线程释放锁的瞬时执行。
Locked
The query is locked by another query.
As of MySQL 5.5.3, this state was removed because it was equivalent to the Table lock state and no longer appears in SHOW PROCESSLIST output.
这个查询被其他查询锁住了。
在MySQL 5.5.3版本,这个状态被移除了。因为它相当于表锁状态,并且不再出现在SHOW PROCESSLIST输出中。
logging slow query
The thread is writing a statement to the slow-query log.
这个线程正在将语句写入慢查询日志。
NULL
This state is used for the SHOW PROCESSLIST state.
没有操作的状态。
login
The initial state for a connection thread until the client has been authenticated successfully.
线程连接的初始状态。直到客户端已经成功验证。
manage keys
The server is enabling or disabling a table index.
服务器启用或禁用表索引。
Opening tables, Opening table
The thread is trying to open a table. This is should be very fast procedure, unless something prevents opening. For example, an ALTER TABLE or a LOCK TABLE statement can prevent opening a table until the statement is finished. It is also worth checking that your table_open_cache value is large enough.
线程正试图打开一张表。这应该是非常快的过程,除非打开受到阻止。一个ALTER TABLE 或LOCK TABLE语句能够阻止打开一张表直到语句运行结束。有必要检查table_open_cache的值是否足够大。
optimizing
The server is performing initial optimizations for a query.
服务器执行查询的初步优化。
preparing
This state occurs during query optimization.
在查询优化过程中出现这个状态。
Purging old relay logs
The thread is removing unneeded relay log files.
线程正在移除不必要的中继日志文件。
query end
This state occurs after processing a query but before the freeing items state.
这个状态出现在处理一个查询之后,但是在freeing items状态之前。
Reading from net
The server is reading a packet from the network.
服务器正在从网络阅读数据包。
Removing duplicates
The query was using SELECT DISTINCT in such a way that MySQL could not optimize away the distinct operation at an early stage. Because of this, MySQL requires an extra stage to remove all duplicated rows before sending the result to the client.
查询正在使用SELECT DISTINCT,这种情况下MySQL不能在早期阶段优化掉一些distinct操作。因此,MySQL需要一个额外的阶段,在将结果发送到客户端之前删除所有重复的行。
removing tmp table
The thread is removing an internal temporary table after processing a SELECT statement. This state is not used if no temporary table was created.
线程正在移除一个内置临时表,在执行一条SELECT语句之后。 如果没有临时表产生,那么这个状态不被使用。
rename
The thread is renaming a table.
线程正在重命名一张表。
rename result table
The thread is processing an ALTER TABLE statement, has created the new table, and is renaming it to replace the original table.
线程正在处理ALTER TABLE语句,创建新的表,并且重命名它来代替原有的表。
Reopen tables
The thread got a lock for the table, but noticed after getting the lock that the underlying table structure changed. It has freed the lock, closed the table, and is trying to reopen it.
线程获得了表锁,但是在取得表锁之后才发现该表的底层结构已经发生了变化。线程释放这个锁,关闭表,并试图重新打开该表。
Repair by sorting
The repair code is using a sort to create indexes.
修复代码正在使用一个分类来创建索引。
Repair done
The thread has completed a multi-threaded repair for a MyISAM table.
线程完成一个多线程的MyISAM表的修复。
Repair with keycache
The repair code is using creating keys one by one through the key cache. This is much slower than Repair by sorting.
修复代码正在通过索引缓存一个接一个地使用创建索引。这比通过分类修复要慢很多。
Rolling back
The thread is rolling back a transaction.
线程正在回滚一个事务
Saving state
For MyISAM table operations such as repair or analysis, the thread is saving the new table state to the .MYI file header. State includes information such as number of rows, the AUTO_INCREMENT counter, and key distributions.
对于MyISAM表的类似repair或analysis操作,线程在.MYI文件的头部保存一个新表的状态。状态信息包括行数、自增数、索引分布等等。
Searching rows for update
The thread is doing a first phase to find all matching rows before updating them. This has to be done if the UPDATE is changing the index that is used to find the involved rows.
线程正在进行第一阶段,在更新前寻找所有匹配的行。如果update正在更改用于查找相关行的索引,则必须这么做。
Sending data
The thread is reading and processing rows for a SELECT statement, and sending data to the client. Because operations occurring during this this state tend to perform large amounts of disk access (reads), it is often the longest-running state over the lifetime of a given query.
线程正在读取和处理一条SELECT语句的行,并且将数据发送至客户端。由于在此期间会执行大量的磁盘访问(读操作),这个状态在一个指定查询的生命周期中经常是耗时最长的。
setup
The thread is beginning an ALTER TABLE operation.
线程正开始进行一个ALTER TABLE操作。
Sorting for group
The thread is doing a sort to satisfy a GROUP BY.
线程正在执行一个由GROUP BY指定的排序。
Sorting for order
The thread is doing a sort to satisfy a ORDER BY.
线程正在执行一个由ORDER BY指定的排序。
Sorting index
The thread is sorting index pages for more efficient access during a MyISAM table optimization operation.
线程正在对索引页进行排序,为了对MyISAM表进行操作时获得更优的性能。
Sorting result
For a SELECT statement, this is similar to Creating sort index, but for nontemporary tables.
对于一个SELECT语句,这与创建排序索引相似,但是是对非临时表。
statistics
The server is calculating statistics to develop a query execution plan. If a thread is in this state for a long time, the server is probably disk-bound performing other work.
服务器计算统计去规划一个查询。如果一个线程长时间处于这个状态,这个服务器的磁盘可能在执行其他工作。
System lock
The thread is going to request or is waiting for an internal or external system lock for the table. If this state is being caused by requests for external locks and you are not using multiple mysqld servers that are accessing the same MyISAM tables, you can disable external system locks with the --skip-external-locking option. However, external locking is disabled by default, so it is likely that this option will have no effect. For SHOW PROFILE, this state means the thread is requesting the lock
(not waiting for it).
这个线程正在请求或者等待一个内部的或外部的系统表锁。如果这个状态是由于外部锁的请求产生的,并且你没有使用多个正在访问相同的表的mysqld服务器,那么你可以使用--skip-external-locking选项禁用外部系统锁。然而,外部系统锁默认情况下禁用,因此这个选项可能不会产生效果。对于SHOW PROFILE,这个状态意味着线程正在请求锁。(而非等待)
Table lock
The next thread state after System lock. The thread has acquired an external lock and is going to request an internal table lock.
This state was replaced in MySQL 5.5.6 with Waiting for table level lock.
系统锁定后的下一个线程状态。线程已获得外部锁并且将请求内部表锁。
这个状态在MySQL 5.5.6版本中被Waiting for table level lock取代。
Updating
The thread is searching for rows to update and is updating them.
线程寻找更新匹配的行并进行更新。
updating main table
The server is executing the first part of a multiple-table update. It is updating only the first table, and saving columns and offsets to be used for updating the other (reference) tables.
线程正在执行多表更新的第一部分,只从第一个表中更新。并且保存列和偏移量用来从其他(参考)表更新。
updating reference tables
The server is executing the second part of a multiple-table update and updating the matched rows from the other tables.
线程正在执行多表更新的第二部分,并从其他表中更新匹配的行。
User lock
The thread is going to request or is waiting for an advisory lock requested with a GET_LOCK() call. For SHOW PROFILE, this state means the thread is requesting the lock (not waiting for it).
线程正在请求或等待一个GET_LOCK()调用所要求的咨询锁。对于SHOW PROFILE,这个状态意味这线程正在请求锁。(而非等待)
User sleep
The thread has invoked a SLEEP() call.
线程调用了一个SLEEP()。
Waiting for all running commits to finish
A statement that causes an explicit or implicit commit is waiting for release of a read lock. This state was removed in MySQL 5.5.8; Waiting for commit lock is used instead.
一个显式或隐式语句在提交时等待释放读锁。这个状态在MySQL 5.5.8版本中被移除,以Waiting for commit lock代替。
Waiting for commit lock
A statement that causes an explicit or implicit commit is waiting for release of a read lock or FLUSH TABLES WITH READ LOCK) is waiting for a commit lock. This state was added in MySQL 5.5.8.
同上,这个状态于MySQL 5.5.8版本加入。
Waiting for global read lock
FLUSH TABLES WITH READ LOCK) is waiting for a global read lock.
等待全局读锁。
Waiting for release of readlock
The thread is waiting for a global read lock obtained by another thread (with FLUSH TABLES WITH READ LOCK) to be released.This state was removed in MySQL 5.5.8; Waiting for global read lock or Waiting for commit lock are used instead.
等待释放读锁。
Waiting for tables, Waiting for table, Waiting for table flush
The thread got a notification that the underlying structure for a table has changed and it needs to reopen the table to get the new structure. However, to reopen the table, it must wait until all other threads have closed the table in question.
This notification takes place if another thread has used FLUSH TABLES or one of the following statements on the table in question: FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE, or OPTIMIZE TABLE.
In MySQL 5.5.6, Waiting for table was replaced with Waiting for table flush.
线程获得一个通知,底层表结构已经发生变化,它需要重新打开表来获取新的结构。然而,重新打开表,它必须等到所有其他线程关闭这个有问题的表。
这个通知产生通常因为另一个线程对问题表执行了FLUSH TABLES或者以下语句之一:FLUSH TABLES tbl_name, ALTER TABLE, RENAME TABLE, REPAIR TABLE, ANALYZE TABLE, or OPTIMIZE TABLE.
Waiting for lock_type lock
The server is waiting to acquire a lock, where lock_type indicates the type of lock:
• Waiting for event metadata lock (added in MySQL 5.5.8)
• Waiting for global metadata lock (replaced by Waiting for global read lock in MySQL 5.5.8)
• Waiting for global read lock (added in MySQL 5.5.8)
• Waiting for schema metadata lock
• Waiting for stored function metadata lock
• Waiting for stored procedure metadata lock
• Waiting for table level lock
• Waiting for table metadata lock
• Waiting for trigger metadata lock (added in MySQL 5.5.8)
等待各个种类的表锁。
Waiting on cond
A generic state in which the thread is waiting for a condition to become true. No specific state information is available.
一个普通的状态,线程正在等待一个条件为真。没有特定的状态信息可用。
Waiting to get readlock
The thread has issued a FLUSH TABLES WITH READ LOCK statement to obtain a global read lock and is waiting to obtain the lock. This state was removed in MySQL 5.5.8; Waiting for global read lock is used instead.
线程发出了一个FLUSH TABLES WITH READ LOCK语句来获取一个全局读锁,并且等待获得这个锁。这个状态在MySQL 5.5.8被移除,使用Waiting for global read lock 来代替。
Writing to net
The server is writing a packet to the network.
服务器正在写一个网络数据包。
发表评论
-
mysql 查询指定索引
2017-07-13 12:25 1022select * from course c f ... -
MYSQL 函数 游标
2017-05-15 20:23 562CREATE PROCEDURE `test`.`new_ ... -
mysql 查看数据库是否有写操作(通过mysqlbin)
2016-10-08 18:29 650/usr/local/mysql/bin/mysqlbin ... -
Using filesort
2015-03-23 18:52 485只有在order by 数据列的时候才可能会出现using f ... -
MySQL STRAIGHT_JOIN
2015-03-23 18:36 702MySQL STRAIGHT_JOIN STRAIGHT_JO ... -
mysql密码忘记后重置
2014-12-30 15:51 4921./etc/init.d/mysql stop 2.以安全模 ... -
mysql的tmp_table_size和max_heap_table_size
2014-10-29 17:34 952先说下tmp_table_size吧: 它规定了内部内存临时表 ... -
mysql 主从复制常见问题
2014-10-14 09:47 11751.问题一:主从复制, ... -
Mysql 表所查询
2014-09-23 10:09 556可以通过检查 table_locks_waited和table ... -
Mysql 语句避免重复插入 Insert Select Not Exist
2014-09-18 17:33 931插入数据时,如果为了避免重复插入,而不像通过两次Sql进 可以 ... -
mysql in not in exist not exist 区别
2014-09-17 19:59 3435Mysql In Not In 不对null 进行处理 如果子 ... -
MySQL小误区:关于set global sql_slave_skip_counter=N 命令
2014-09-17 19:22 482背景知识1: 在主 ... -
mysql 从数据库slave 状态为no的解决方法
2014-09-11 12:08 668从数据库的状态显示为如下 Slave_IO_Running ... -
MySQL里获取当前week、month、quarter的start_date/end_date
2014-08-12 19:35 764当前week第一天 select date_sub(cur ... -
mysql 日期计算
2014-08-06 18:04 0mysql date()函数 MySQL DATE_SUB() ...
相关推荐
8. `SHOW PROCESSLIST`: 显示当前正在执行的查询和事务,帮助诊断慢查询或并发问题。 9. `SHOW TABLE STATUS`: 提供关于数据库中每个表的详细信息,包括表的类型、大小、最后修改时间等。 10. `SHOW PRIVILEGES`: ...
8. 显示系统中正在运行的所有进程:show processlist; 这条命令可以显示系统中正在运行的所有进程,也就是当前正在执行的查询。大多数用户可以查看他们自己的进程,但是如果他们拥有process权限,就可以查看所有人...
8. **`SHOW PROCESSLIST;`** - 显示当前运行的查询和线程,帮助识别潜在的阻塞问题。 9. **`SHOW TABLE STATUS;`** - 提供每个表的详细信息,包括表类型、更新时间、行数等。 10. **`SHOW PRIVILEGES;`** - 列出...
- show processlist:显示MySQL系统中正在运行的所有进程,也就是当前正在执行的查询。一般用户可以看到他们自己的进程,如果用户拥有process权限,可以查看所有人的进程,包括密码。 4. 显示表的详细信息 - show...
怎么进入mysql命令行呢? mysql的安装目录下面有个bin...只列出前100条,如果想全列出请使用show full processlist; mysql> show processlist; 命令: show status; 命令:show status like ‘%下面变量%’; Aborted_
SHOW VARIABLES SHOW VARIABLES是查看MySQL的配置参数,还可以使用类似SHOW VARIABLES LIKE ‘Key%’ SHOW PROCESSLIST SHOW PROCESSLIST是查看当前正在进行的进程,对于有锁表等情况的排查很有用处。一般情况下,...
7. `SHOW [FULL] PROCESSLIST;`:显示当前正在执行的查询列表,帮助诊断阻塞和性能问题。`FULL`选项会显示查询的完整文本。 8. `SHOW TABLE STATUS [FROM db_name];`:提供关于表的详细信息,包括表类型、行格式、...
- **命令**: `SHOW TABLE STATUS;` - **功能**: 获取当前使用的数据库中每个表的信息,包括表名、类型、行数等。 - **示例**: ```sql SHOW TABLE STATUS; ``` #### 10. 显示支持的权限 - **命令**: `SHOW ...
- **SHOW VARIABLES**:与 SHOW STATUS 类似,该命令用于显示 MySQL 的系统变量,同样可以通过 LIKE 关键字来过滤显示特定变量。 ```sql SHOW VARIABLES; SHOW VARIABLES LIKE 'log_%'; ``` 2. **使用 SHOW ...
8. `SHOW PROCESSLIST;` 查看当前正在执行的查询和进程,有助于诊断性能问题和阻塞情况。 9. `SHOW TABLE STATUS;` 提供关于数据库中每个表的详细信息,如表类型、创建时间、大小等。 10. `SHOW PRIVILEGES;` ...
最后,MySQL提供了一个“SHOW PROCESSLIST”命令,让DBA可以直接查看当前所有活动进程的状态信息,包括id、user、host、db、command、time、state、info等列。其中,id为连接标识,user显示当前用户,host指示命令...
8. `SHOW PROCESSLIST;` - 显示所有正在执行的查询和进程,帮助识别阻塞和慢查询。 9. `SHOW TABLE STATUS [FROM database_name];` - 提供每个表的详细信息,包括表类型、记录数、数据大小、创建时间等。 10. `...
今天发现Mysql的主从数据库没有同步 先上Master库: mysql>show processlist; 查看下进程是否Sleep太多。发现很正常。 show master status; 也正常。 mysql> show master status; +——————-+———-+————–...
10. SHOW PROCESSLIST: 此命令用于显示当前运行的线程(进程),通常与show full processlist一起使用以查看MySQL的连接数和详细信息。如果用户拥有SUPER权限,则可以看到所有线程信息。 11. SHOW VARIABLES: 此...
- **监控状态**:使用 `show processlist` 和 `show slave status` 检查从服务器是否已连接并开始复制。 ```sql mysql> show processlist; mysql> show slave status; ``` 当 `Slave_IO_Running` 和 `Slave_...
此外,通过 `show processlist` 和 `show full processlist` 监控数据库连接和进程,确保无异常阻塞,同时监控 `aborted_connects` 和死掉的连接数,防止过多无效连接影响数据库性能。 在资源使用方面,CPU、内存和...
在进行主从测试时,可以在主服务器上查看`show processlist\G;`,确认存在Binlog Dump进程,表明从服务器正在同步数据。同时,从服务器应无明显错误,`SHOW SLAVE STATUS\G;`的结果应显示正常运行。 总的来说,...
1, see the slow log status; mysql> show variables like ‘%slow%’;+———————+——————————————+| Variable_name | Value |+———————+——————————————+| log_slow_...
3. **SHOW PROCESSLIST;** 此命令显示当前运行的MySQL进程列表,包括正在执行的查询。这对于监控系统性能,特别是当遇到慢查询时,可以找出是哪个查询导致的问题。 4. **SHOW TABLE STATUS;** 它提供当前数据库中...