MySQL Server has gone away报错原因有哪些
本篇文章为大家展示了MySQL Server has gone away报错原因有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
背景
平时与开发交流,或在论坛回答问题时,发现这个问题被问及的频率非常高,例如: 程序中报错“MySQL server has gone away”是什么意思? 如何避免? 因此,感觉有必要总结一下发生这个问题的原因。
正好看到一篇外文blog总结的比较好,就翻译过来了,分享给大家。
原因一: MySQL 服务宕了
判断是否属于这个原因的方法很简单,执行以下命令,查看mysql的运行时长:
$mysql-uroot-p-e"showglobalstatuslike'uptime';"+---------------+-------+|Variable_name|Value|+---------------+-------+|Uptime|68928|+---------------+-------+1rowinset(0.04sec)
或者查看MySQL的报错日志,看看有没有重启的信息:
$tail/var/log/mysql/error.log13010122:22:30InnoDB:Initializingbufferpool,size=256.0M13010122:22:30InnoDB:Completedinitializationofbufferpool13010122:22:30InnoDB:highestsupportedfileformatisBarracuda.13010122:22:30InnoDB:1.1.8started;logsequencenumber6344432550913010122:22:30[Note]Serverhostname(bind-address):'127.0.0.1';port:330613010122:22:30[Note]-'127.0.0.1'resolvesto'127.0.0.1';13010122:22:30[Note]ServersocketcreatedonIP:'127.0.0.1'.13010122:22:30[Note]EventScheduler:Loaded0events13010122:22:30[Note]/usr/sbin/mysqld:readyforconnections.Version:'5.5.28-cll'socket:'/var/lib/mysql/mysql.sock'port:3306MySQLCommunityServer(GPL)
如果uptime数值很大,表明MySQL服务运行了很久了,说明最近服务没有重启过。 如果日志没有相关信息,也说明MySQL服务最近没有重启过,可以继续检查下面几项内容。
原因2:连接超时
如果程序使用的是长连接,则这种情况的可能性会比较大。 即某个长连接很久没有发起新的请求,达到了server端的time out,被server强行关闭。此后再通过这个client发起查询的时候,就会报错server has gone away。
$mysql-uroot-p-e"showglobalvariableslike'%timeout';"+----------------------------+----------+|Variable_name|Value|+----------------------------+----------+|connect_timeout|30||delayed_insert_timeout|300||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||slave_net_timeout|3600||wait_timeout|28800|+----------------------------+----------+mysql>SETSESSIONwait_timeout=5;#Wait10secondsmysql>SELECTNOW();ERROR2006(HY000):MySQLserverhasgoneawayNoconnection.Tryingtoreconnect...Connectionid:132361Currentdatabase:***NONE***+---------------------+|NOW()|+---------------------+|2013-01-0211:31:15|+---------------------+1rowinset(0.00sec)
原因3: 进程在server端被主动kill
这种原因和第2种原因比较相似,只是发起者是DBA,或者其他job,发现有长时间的慢查询执行kill xxx导致。
$mysql-uroot-p-e"showglobalstatuslike'com_kill'"+---------------+-------+|Variable_name|Value|+---------------+-------+|Com_kill|0|+---------------+-------+
原因4: Your SQL statement was too large
当查询的结果集超过 max_allowed_packet 也会出现这样的报错,定位方法是打出相关报错的语句。 用select*into outfile 的方式导出到文件,查看文件大小是否超过max_allowed_packet,如果超过则需要调整参数,或者优化语句。
mysql>showglobalvariableslike'max_allowed_packet';+--------------------+---------+|Variable_name|Value|+--------------------+---------+|max_allowed_packet|1048576|+--------------------+---------+1rowinset(0.00sec)#修改参数:mysql>setglobalmax_allowed_packet=1024*1024*16;mysql>showglobalvariableslike'max_allowed_packet';+--------------------+----------+|Variable_name|Value|+--------------------+----------+|max_allowed_packet|16777216|+--------------------+----------+1rowinset(0.00sec)
上述内容就是MySQL Server has gone away报错原因有哪些,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。