mysql err 2006_MySQL导入.sql文件时报错:[Err] 2006 - MySQL server has gone away 的解决办法记录...

最近网站流量增加,以前的主机已不能满足现在的访问量。于是,打算换主机,本来觉得换个主机给网站搬个家不是个事儿呢。结果,在实际操作过程中出了不少岔子,今天就来记录总结下。

a1dcf606d57f74b3f8160b77e0d49e5d.png

背景

在把网站数据库备份文件(.sql 文件)导入新的数据库时,出现了“[Err] 2006 - MySQL server has gone away”错误提示。

原因

可能是 sql 语句过长(sql 文件过大),超过 mysql 通信缓存区最大长度。

解决办法

找到 mysql 安装目录下的 my.ini 配置文件,加入以下代码:

max_allowed_packet=50M

参数注释如下:

max_allowed_packet 是 mysql 允许最大的数据包,用来控制其通信缓冲区的最大长度。

最后重启下 mysql 服务。就解决了我的问题,不过造成这个问题的原因还有其他几种。

延伸

1、应用程序(比如 PHP)长时间的执行批量的 MYSQL 语句。

最常见的就是采集或者新旧数据转化。

解决方案:

在 my.ini 文件中添加或者修改以下两个变量:

wait_timeout=2880000

interactive_timeout = 2880000

2、执行一个 SQL,但 SQL 语句过大或者语句中含有 BLOB 或者 longblob 字段。

比如,图片数据的处理。解决方案是:

在 my.ini 文件中添加或者修改以下变量:

max_allowed_packet = 10M(默认为 1M,也可以设置自己需要的大小)

max_allowed_packet 参数的作用是,用来控制其通信缓冲区的最大长度。

最保险的方法:

将 2 段代码都加上:

max_allowed_packet=50M

wait_timeout=288000

interactive_timeout = 288000

声明:此资源由沃森博客 [wosn.net] 收集整理于网络,如有侵权,请联系沃森博客 [admin@wosn.net] 删除处理。

沃森博客(wosn.net)--- 专注于 PHP 技术和资源分享!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值