Navicat卡死动不了怎么办?show processlist 神器来救场!

今天在同步测试数据时,网突然断了,等到重连之后,发现表打不开了。

可以看到表的数据长度已有112192kb,可惜打不开了。

打不开,就准备删掉重来。

事情往往没这么简单,果然删不掉,truncate也不行,然后navicat卡死,遂登上数据库,执行dorp操作,还是不行。

估计是网络错误,导致了一些奇怪的事情发生。

那么就一起看看,到底发生了什么吧。

神器登场。

show full processlist;

show full processlist 返回的结果是实时变化的,是对mysql链接执行的现场快照,所以用来处理突发事件非常有用。
这个sql,一般就是充当救火队员的角色,解决一些突发性的问题。

它可以查看当前mysql的一些运行情况,是否有压力,都在执行什么sql,语句耗时几何,有没有慢sql在执行等等。

当发现一些执行时间很长的sql时,就需要多注意一下了,必要时kill掉,先解决问题。

命令有三种执行方式:

1、这种是直接在命令行查询,末尾带\G是表示将查询结果进行按列打印,可以使每个字段打印到单独的行。」

mysql> show full processlist;
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
| Id     | User | Host                 | db    | Command | Time | State    | Info                  |
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
| 449000 | root | 127.123.213.11:59828 | stark | Sleep   | 1270 |          | NULL                  |
| 449001 | root | 127.123.213.11:59900 | stark | Sleep   | 1241 |          | NULL                  |
| 449002 | root | 127.123.213.11:59958 | stark | Sleep   | 1216 |          | NULL                  |
| 449003 | root | 127.123.213.11:60088 | stark | Sleep   | 1159 |          | NULL                  |
| 449004 | root | 127.123.213.11:60108 | stark | Sleep   | 1151 |          | NULL                  |
| 449005 | root | 127.123.213.11:60280 | stark | Sleep   | 1076 |          | NULL                  |
| 449006 | root | 127.123.213.11:60286 | stark | Sleep   | 1074 |          | NULL                  |
| 449007 | root | 127.123.213.11:60344 | stark | Sleep   | 1052 |          | NULL                  |
| 449008 | root | 127.123.213.11:60450 | stark | Sleep   | 1005 |          | NULL                  |
| 449009 | root | 127.123.213.11:60498 | stark | Sleep   |  986 |          | NULL                  |
| 449013 | root | localhost            | NULL  | Query   |    0 | starting | show full processlist |
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
11 rows in set (0.01 sec)
mysql> show full processlist\G;
*************************** 1. row ***************************
     Id: 449000
   User: root
   Host: 127.123.213.11:59828
     db: stark
Command: Sleep
   Time: 1283
  State: 
   Info: NULL
*************************** 2. row ***************************
     Id: 449001
   User: root
   Host: 127.123.213.11:59900
     db: stark
Command: Sleep
   Time: 1254
  State: 
   Info: NULL

2、通过查询链接线程相关的表来查看快照」

SELECT id, db, USER, HOST, command, time, state, info FROM information_schema. PROCESSLIST WHERE command != 'Sleep' ORDER BY time DESC;

3、通过navicat中的【工具】=> 【服务器监控】进行查看。」

这种方式比较方便,还可以排序。

简单介绍一下,每列的含义:

  • Id:链接mysql 服务器线程的唯一标识,可以通过kill来终止此线程的链接。
  • User:当前线程链接数据库的用户
  • Host:显示这个语句是从哪个ip 的哪个端口上发出的。可用来追踪出问题语句的用户
  • db: 线程链接的数据库,如果没有则为null
  • Command: 显示当前连接的执行的命令,一般就是休眠或空闲(sleep),查询(query),连接(connect)
  • Time: 线程处在当前状态的时间,单位是秒
  • State:显示使用当前连接的sql语句的状态,很重要的列,后续会有所有的状态的描述,请注意,state只是语句执行中的某一个状态,一个 sql语句,已查询为例,可能需要经过copying to tmp table,Sorting result,Sending data等状态才可以完成
  • Info: 线程执行的sql语句,如果没有语句执行则为null。这个语句可以使客户端发来的执行语句也可以是内部执行的语句

发现问题之后怎样解决它呢?

1、可以单独kill掉上面有问题的行

kill 449000

2、也可以批量结束时间超过3分钟的线程

-- 查询执行时间超过3分钟的线程,然后拼接成 kill 语句
select concat('kill ', id, ';')
from information_schema.processlist
where command != 'Sleep'
and time > 3*60
order by time desc;

当然问题到这,一般都能解决了,但是本次在show processlist过程中,只是看到了前面的truncate和drop操作,把这两个线程kill了,也没啥用。。。。

当然上面这些不是废话昂,这就是类似方法论的东西,就像【中国机长】里面,遇到飞行事故时,首先按照手册,检查一遍,排查原因,解决问题。

继续

紧接着,又用navicat执行了修复表操作,结果返回了Waiting for table metadata lock

当MySQL在进行一些alter table等DDL操作时,如果该表上有未提交的事务则会出现 Waiting for table metadata lock,而一旦出现metadata lock,该表上的后续操作都会被阻塞。

解决办法:

1、从 information_schema.innodb_trx 表中查看当前未提交的事务」

select trx\_state, trx\_started, trx\_mysql\_thread\_id, trx\_query from information\_schema.innodb\_trx\\G

字段意义:

  • trx_state: 事务状态,一般为RUNNING
  • trx_started: 事务执行的起始时间,若时间较长,则要分析该事务是否合理
  • trx_mysql_thread_id: MySQL的线程ID,用于kill
  • trx_query: 事务中的sql

一般只要kill掉这些线程,DDL操作就不会Waiting for table metadata lock。

2、调整锁超时阈值」

lock_wait_timeout 表示获取metadata lock的超时(单位为秒),允许的值范围为1到31536000(1年)。默认值为31536000。
详见

https://dev.mysql.com/doc/refman/5.6/en/server-system-variables.html#sysvar_lock_wait_timeout

默认值为一年。。。。
将其调整为30分钟

  • set session lock_wait_timeout = 1800;
  • set global lock_wait_timeout = 1800;

好让出现该问题时快速失败(failfast)

<think>好的,用户想解决Navicat卡死的问题。我需要根据提供的引用资料来分析可能的原因和解决方法。首先,引用[1]提到长时间不操作或网络不好会导致连接断开,再次操作时卡死。这可能是因为连接超时设置的问题,或者网络不稳定导致Navicat无法维持连接。解决方法可能涉及调整超时设置或检查网络连接。 然后,引用[2]指出数据库中的某些进程可能导致卡死,比如执行长时间运行的SQL语句,如添加或删除索引。这时候需要进入数据库管理界面,查看当前进程,找到卡死的查询并终止它。这可能需要使用类似`SHOW PROCESSLIST;`和`KILL`命令。 引用[3]提到导入大文件时Navicat卡死,可能因为软件处理大文件的能力有限。解决方法建议改用命令行或其他工具导入,比如MySQL的命令行工具,或者拆分SQL文件。 接下来,我需要将这些原因和解决方法整理成结构清晰的回答。可能需要分点列出原因,每个原因对应解决方法。同时,用户可能需要步骤说明,比如如何调整超时设置,如何终止进程,如何用命令行导入数据。需要注意使用中文,符合格式要求,比如行内公式用$...$,但这里可能涉及较少数学内容,更多是步骤和命令。 还要检查是否遗漏其他可能的原因,比如软件本身的问题,缓存不足,或者系统资源占用过高。但根据提供的引用,主要原因是连接超时、长时间查询和大文件导入。应该围绕这三个方面展开,确保回答真实可靠,引用来源正确标注。 最后,生成相关问题,可能涉及如何优化Navicat性能,如何监控数据库进程,处理大文件的其他方法等。要确保问题与用户的需求相关,并且基于已有的信息。</think>### Navicat卡死原因及解决方法 #### 一、连接超时或网络不稳定 1. **原因** Navicat默认设置了连接超时机制。若长时间未操作或网络波,可能导致连接断开,再次操作时因重新建立连接而卡死[^1]。 2. **解决方法** - **调整超时设置**:在Navicat中依次选择 **工具 > 选项 > 连接**,将`保持连接间隔`设置为较低值(如60秒)。 - **检查网络稳定性**:使用`ping`命令测试数据库服务器延迟,确保网络通畅。 #### 二、数据库进程阻塞 1. **原因** 长时间运行的SQL语句(如未优化的查询、索引操作)可能占用资源,导致数据库卡死[^2]。 2. **解决方法** - **查看当前进程**:在Navicat中执行 `SHOW PROCESSLIST;`,找到状态为`Sending data`或`Waiting`的进程。 - **终止阻塞进程**:对问题进程执行 `KILL <进程ID>;`(如 `KILL 1025;`)。 #### 三、大文件导入导致资源耗尽 1. **原因** 导入大型SQL文件时,Navicat可能因内存不足或处理效率低而卡死[^3]。 2. **解决方法** - **使用命令行导入**:通过MySQL命令行执行 `mysql -u用户 -p密码 数据库名 < 文件.sql`。 - **拆分SQL文件**:用文本编辑器将大文件拆分为多个小文件分批导入。 #### 四、其他常见原因 - **软件版本过旧**:升级Navicat至最新版本。 - **系统资源不足**:关闭不必要的程序,释放内存和CPU资源。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值