今天在用Navicat 16.0.6导入.sql文件时,运行一半就报错了。错误如下:
[Err] 2006 - MySQL server has gone away
sql文件运行出错,第一反应就是文件内容过大,后来发现是navicat软件默认限制了上传sql语句的大小,修改方法很简单。
1、打开 工具--> 服务器监控-->mysql
如下图所示:

2、选择 变量 ,找到 max_allowed_packect ,修改它的值为 999999448 即可。
如下图所示:

在导入sql脚本过程中出现2006错误的情况很多,以下收集几种情况作为参考:
判断是否属于这个原因的方法很简单,进入mysql控制台,查看mysql的运行时长或者查看MySQL的报错日志,看看有没有重启的信息—— 如果uptime数值很大,表明mysql服务运行了很久了。说明最近服务没有重启过。 如果日志没有相关信息,也表名mysql服务最近没有重启过,可以继续检查下面几项内容。
- mysql> show global status like 'uptime';
- +---------------+--------+
- | Variable_name | Value |
- +---------------+--------+
- | Uptime | 125695 |
- +---------------+--------+
- 1 row in set (0.00 sec)
即某个mysql长连接很久没有新的请求发起,达到了server端的timeout,被server强行关闭。 此后再通过这个connection发起查询的时候,就会报错server has gone away (大部分PHP脚本就是属于此类)
- mysql> show global variables like '%timeout';
- +-----------------------------+----------+
- | Variable_name | Value |
- +-----------------------------+----------+
- | connect_timeout | 10 |
- | delayed_insert_timeout | 300 |
- | have_statement_timeout | YES |
- | innodb_flush_log_at_timeout | 1 |
- | innodb_lock_wait_timeout | 50 |
- | innodb_rollback_on_timeout | OFF |
- | interactive_timeout | 28800 |
- | lock_wait_timeout | 31536000 |
- | net_read_timeout | 30 |
- | net_write_timeout | 60 |
- | rpl_stop_slave_timeout | 31536000 |
- | slave_net_timeout | 60 |
- | wait_timeout | 28800 |
- +-----------------------------+----------+
- 13 rows in set (0.01 sec)
wait_timeout 是28800秒,即mysql链接在无操作28800秒后被自动关闭
这种情况和原因二相似,只是一个是人为一个是MYSQL自己的动作
- mysql> show global status like 'com_kill';
- +---------------+-------+
- | Variable_name | Value |
- +---------------+-------+
- | Com_kill | 10 |
- +---------------+-------+
- 1 row in set (0.00 sec)
当查询的结果集超过 max_allowed_packet 也会出现这样的报错。定位方法是打出相关报错的语句。 用select * into outfile 的方式导出到文件,查看文件大小是否超过 max_allowed_packet ,如果超过则需要调整参数,或者优化语句。
- mysql> show global variables like 'max_allowed_packet';
- +--------------------+----------+
- | Variable_name | Value |
- +--------------------+----------+
- | max_allowed_packet | 20971520 |
- +--------------------+----------+
- 1 row in set (0.00 sec)