MySQL server has gone away的问题解决

 更新时间:2024年07月21日 10:38:59   作者:半桶水专家  
本文主要介绍了MySQL server has gone away的问题解决,意思就是指client和MySQL server之间的链接断开了,下面就来介绍一下几种原因及其解决方法,感兴趣的可以了解一下

一、可能是mysql连接超时

原因:mysql长连接时,很长时间没有新的请求发起到达服务端,当这个时间超过配置的最大超时时间时,mysql就会强行关闭链接。此后再通过这个connection发起查询的时候,就会报错server has gone away。

解决办法:可以将timeout时间设置长一点:

set global wait_timeout =3600 ; //非交互式链接

set global interactive_timeout=3600 ; //交互式链接

但是这样会长时间占用mysql链接,消耗资源。

二、可能是发送的SQL语句太长

原因:mysql服务器端和客户端在一次传送数据包的过程中,数据包的大小大于max_allowed_packet设置的值。

解决办法:可以将max_allowed_packet值设置大一点,set global max_allowed_packet=3600。

三、可能MySQL 服务宕了

可以查看mysql的运行时长:show global status like 'uptime'; 。来判断是否属于这个原因引起的。

uptime很长说明mysql运行很长时间了,排除mysql服务宕机的可能。

扩展:

应用程序长时间的执行批量的MYSQL语句。执行一个SQL,但SQL语句过大或者语句中含有BLOB或者longblob字段。比如,图片数据的处理。都容易引起MySQL server has gone away。 

解决MySQL server has gone away :

1、应用程序长时间的执行批量的MYSQL语句。最常见的就是采集或者新旧数据转化。或者长时间闲置数据库连接

解决方案: 

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

wait_timeout=2880000 
interactive_timeout = 2880000 

如果不能修改my.cnf/my.ini,则可以在连接数据库的时候设置CLIENT_INTERACTIVE,比如:

sql = "set interactive_timeout=24*3600"; 
mysql_real_query(...) 

2、执行一个SQL,但SQL语句过大或者语句中含有BLOB或者longblob字段。比如,图片数据的处理 

解决方案: 

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

max_allowed_packet = 10M(也可以设置自己需要的大小) 

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

到此这篇关于MySQL server has gone away的问题解决的文章就介绍到这了,更多相关MySQL server has gone away内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL中的整型类型示例详解

    MySQL中的整型类型示例详解

    MySQL数据库支持多种数据类型,其中数值类型用于存储数字数据,这篇文章主要介绍了MySQL中整型类型的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-10-10
  • MySQL开启慢查询日志log-slow-queries的方法

    MySQL开启慢查询日志log-slow-queries的方法

    MySQL中提供了一个慢查询的日志记录功能,可以把查询SQL语句时间大于多少秒的语句写入慢查询日志,日常维护中可以通过慢查询日志的记录信息快速准确地判断问题所在
    2016-05-05
  • 解析优化MySQL插入方法的五个妙招

    解析优化MySQL插入方法的五个妙招

    本篇文章是对优化MySQL插入方法的五个妙招进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • mysql误删root用户或者忘记root密码解决方法

    mysql误删root用户或者忘记root密码解决方法

    mysql误删root用户或者忘记root密码解决方法,需要的朋友可以参考下。
    2011-05-05
  • mysql 触发器创建与使用方法示例

    mysql 触发器创建与使用方法示例

    这篇文章主要介绍了mysql 触发器创建与使用方法,结合实例形式分析了mysql 触发器基本概念、原理、创建、使用方法及操作注意事项,需要的朋友可以参考下
    2020-05-05
  • mysql int(3)与int(11)的区别详解

    mysql int(3)与int(11)的区别详解

    这篇文章主要介绍了mysql int(3)与int(11)的区别详解的相关资料,需要的朋友可以参考下
    2016-09-09
  • mysql 5.7.17 安装教程 附MySQL服务无法启动的解决方法

    mysql 5.7.17 安装教程 附MySQL服务无法启动的解决方法

    这篇文章主要为大家详细介绍了mysql 5.7.17安装教程,并且为大家分享了MySQL服务无法启动的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • MySql恢复数据方法梳理讲解

    MySql恢复数据方法梳理讲解

    MySQL的binlog日志是MySQL日志中非常重要的一种日志,下面这篇文章主要给大家介绍了关于mysql如何利用binlog进行数据恢复的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • mysql外键创建不成功/失效如何处理

    mysql外键创建不成功/失效如何处理

    文章介绍了在MySQL 5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`student`表的`id`字段更新,并且没有删除的限制,问题的原因是使用了不支持外键的`MyISAM`引擎,而使用了支持外键的`InnoDB`引擎即可解决
    2025-01-01
  • MySQL 8.0 新特性之哈希连接(Hash Join)

    MySQL 8.0 新特性之哈希连接(Hash Join)

    MySQL 开发组于 2019 年 10 月 14 日 正式发布了 MySQL 8.0.18 GA 版本,带来了一些新特性和增强功能。这篇文章主要介绍了MySQL 8.0 新特性之哈希连接(Hash Join),需要的朋友可以参考下
    2019-10-10

最新评论