当我试图获取一个大的SQL文件(一个大的INSERT查询)时,我得到这个错误。

mysql>  source file.sql
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id:    2
Current database: *** NONE ***

ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id:    3
Current database: *** NONE ***

表中没有任何内容被更新。我尝试了删除和恢复表/数据库,以及重新启动MySQL。这些都不能解决问题。

这是我的最大数据包大小:

+--------------------+---------+
| Variable_name      | Value   |
+--------------------+---------+
| max_allowed_packet | 1048576 |
+--------------------+---------+

下面是文件大小:

$ ls -s file.sql 
79512 file.sql

当我尝试另一种方法时……

$ ./mysql -u root -p my_db < file.sql
Enter password: 
ERROR 2006 (HY000) at line 1: MySQL server has gone away

当前回答

max_allowed_packet=64M

在my.cnf文件中添加这一行可以解决我的问题。

当列有大值时,这很有用,这会导致问题,你可以在这里找到解释。

在Windows上,这个文件位于:C:\ProgramData\MySQL\MySQL Server 5.6” Linux操作系统(Ubuntu):“/etc/mysql”

其他回答

以防万一,检查你可以使用的变量

$> mysqladmin variables -u user -p 

这将显示当前变量,在本例中是max_allowed_packet,正如有人在另一个答案中所说,您可以临时设置它

mysql> SET GLOBAL max_allowed_packet=1072731894

在我的情况下,cnf文件没有考虑到,我不知道为什么,所以SET GLOBAL代码真的很有帮助。

我在第97行解决了错误error 2006 (HY000): MySQL服务器已经离开,并成功迁移了一个>5GB sql文件,按顺序执行以下两个步骤:

创建了其他人推荐的/etc/my.cnf,内容如下: (mysql) Connect_timeout = 43200 max_allowed_packet = 2048M net_buffer_length = 512M debug-info = TRUE 附加标志——force——wait——重新连接到命令(即mysql -u root -p -h localhost my_db < file. exe)。SQL——verbose——force——wait——reconnect)。

重要提示:执行这两个步骤都是必要的,因为如果我不费心对/etc/my.cnf文件进行更改,也不附加这些标志,导入后会丢失一些表。

系统使用:OSX El Capitan 10.11.5;mysql version 14.14 distribub 5.5.51 for osx10.8

如果您已经尝试了所有这些解决方案,特别是将max_allowed_packet增加到最大支持的1GB,您仍然看到这些错误,这可能是您的服务器没有足够的空闲RAM内存可用…

解决方案=将服务器升级到更大的RAM内存,然后再试一次。

注意:我很惊讶这个简单的解决方案在这个话题上讨论了8年多之后还没有被提及……有时候我们开发人员会想太多。

如何使用mysql客户端像这样:

mysql -h <hostname> -u username -p <databasename> < file.sql

您还可以以root(或SUPER特权)身份登录到数据库并执行该操作

set global max_allowed_packet=64*1024*1024;

不需要重新启动MySQL。注意,你应该修复my.cnf文件,就像在其他解决方案中概述的那样:

[mysqld]
max_allowed_packet=64M

重新启动MySQL后确认更改:

show variables like 'max_allowed_packet';

您也可以使用命令行,但这可能需要更新启动/停止脚本,这些脚本可能无法在系统更新和补丁中保存。

根据要求,我在这里添加了我自己的答案。很高兴看到它工作!