一,线程阻塞
1) show processlist 显示前100条线程:
stat有sleeping等待用户输入,updating正在更新数据,sending update等在把结果发给用户,lock查询被锁。
2) show engine innodb status
3)show innodb status只是其一种模式的直接展现,并且只能交互式开启,无法自动循环捕获信息
innodb状态信息输出到 err 日志 在如何 库 下都可以,推荐在 test 数据库下创建如下表
mysql> create table innodb_monitor(a int) engine=innodb;
Query OK, 0 rows affected (0.09 sec)
创建表后innodb会每过15秒输出一次innodb状态信息到error log,通过删除表停止该monitor功能。
4)通过日志排错:
1.错误日志文件:log_errorobal variables like 'log_error';
+---------------+-----------------------------------------+
| Variable_name | Value
| log_error | /mydata/data1/localhost.localdomain.err |
+---------------+-----------------------------------------+
2.临时打开通用日志:(打开以后所有查询指令都会保存下来,默认关闭)
mysql> set global general_log='on';
Query OK, 0 rows affected (0.00 sec)
这是mysql会在数据目录下生成mydb3.log 文件,记录查询语句
[root@mydb3 mysql]# ls
auto.cnf ib_logfile2 mydb3-relay-bin.000014 mysql test wwang
ib_buffer_pool master.info mydb3-relay-bin.000015 performance_schema uxallowance
ibdata1 mydb3.err mydb3-relay-bin.index relay-log.info uxintegral
ib_logfile0 mydb3.log mydb3-slow.log set uxscan
ib_logfile1 mydb3.pid myslave show uxstatistic
[root@mydb3 mysql]# cat mydb3.log
/usr/local/mysql/bin/mysqld, Version: 5.6.28 (MySQL Community Server (GPL)). started with:
Tcp port: 3306 Unix socket: /tmp/mysql.sock
Time Id Command Argument
160518 7:42:05 187 Query SET PROFILING=1
187 Query SHOW STATUS
3.在有些时候,你会遇到其他人员反映程序执行慢,你怀疑可能是sql 执行慢导致,而又不知道具体的是那一条sql执行导致的,这个时候你可以临时开启慢查询日志,一般情况下慢查询都是开启的
mysql> set global slow_query_log=on;
Query OK, 0 rows affected (0.00 sec)
5)事物相关
查看正在锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
查看等待锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS
kill <线程>
INNODB_TRX表主要是包含了正在InnoDB引擎中执行的所有事务的信息,包括waiting for a lock和running的事务
INNODB_LOCKS表主要包含了InnoDB事务锁的具体情况,包括事务正在申请加的锁和事务加上的锁。
INNODB_LOCK_WAITS表包含了blocked的事务的锁等待的状态