刚进实习公司的第二周,我组长让我为App写两个后台接口,并给我一个比较大的sql文件,我在导入sql文件的时候遇到了问题,在导入sql文件时报了mysql server has fone away错误,导致很多数据没有导入,而且还有乱码,后来上网查了发现是因为insert....values的语句太大,超过了max_allowed_packed配置的值,后来总结了发生mysql server has fone away错误的情况如下:

原因一. MySQL 服务宕了
判断是否属于这个原因的方法很简单,进入mysql控制台,查看mysql的运行时长
mysql> show global status like 'uptime';
+---------------+---------+
| Variable_name | Value   |
+---------------+---------+
| Uptime        | 3414707 |
+---------------+---------+
1 row in set或者查看MySQL的报错日志,看看有没有重启的信息
如果uptime数值很大,表明mysql服务运行了很久了。说明最近服务没有重启过。
如果日志没有相关信息,也表名mysql服务最近没有重启过,可以继续检查下面几项内容。
原因二. mysql连接超时
即某个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      |
| 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    |
+----------------------------+----------+
10 rows in set
wait_timeout 是28800秒,即mysql链接在无操作28800秒后被自动关闭
原因三. mysql请求链接进程被主动kill
这种情况和原因二相似,只是这个是人为上一个是MYSQL自己的动作
mysql> show global status like 'com_kill';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_kill      | 21    |
+---------------+-------+
1 row in set
原因四. Your SQL statement was too large.
当MySQL客户端或mysqld服务器收到大于max_allowed_packet字节的信息包时,将发出“信息包过大”错误,并关闭连接。对于某些客户端,如果通信信息包过大,在执行查询期间,可能会遇到“丢失与MySQL服务器的连接”错误。
客户端和服务器均有自己的max_allowed_packet变量,因此,如你打算处理大的信息包,必须增加客户端和服务器上的该变量。一般情况下,服务器默认max-allowed-packet为1MB
如果你正在使用mysql客户端程序,其max_allowed_packet变量的默认值为16MB。要想设置较大的值,可用下述方式启动mysql
mysql>mysql --max-allowed-packet=32M
用select * into outfile 的方式导出到文件,查看文件大小是否超过 max_allowed_packet ,如果超过则需要调整参数,或者优化语句。
mysql> show global variables like 'max_allowed_packet';
+--------------------+---------+
| Variable_name      | Value   |
+--------------------+---------+
| max_allowed_packet | 1048576 |
+--------------------+---------+
1 row in set (0.00 sec)
修改参数:
mysql> set global max_allowed_packet=1024*1024*16;
mysql> show global variables like 'max_allowed_packet';
+--------------------+----------+
| Variable_name      | Value    |
+--------------------+----------+
| max_allowed_packet | 16777216 |
+--------------------+----------+

1 row in set (0.00 sec)

当然也可以在my.ini中进行配置,如果参数中没有你要修改的参数,就直接在最后加上参数的名称并赋。

mysql server has fone away相关推荐

  1. Can 't connect to local MySQL server through socket '/tmp/mysql.sock '(2)

    安装了mysql, 使用命令mysql -u root -p 弹出Can 't connect to local MySQL server through socket '/tmp/mysql.soc ...

  2. is this mysql server_远程连接MySQL数据库报错:is not allowed to connect to this MYSQL server的解决办法...

    1. 改表法. 可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入MySQL后,更改 "mysql" 数据库里的 " ...

  3. pcntl_fork 导致 MySQL server has gone away 解决方案

    pcntl_fork 前连数据库,就会报 MySQL server has gone away 错误.原因是子进程会继承主进程的数据库连接,当mysql返回数据时,这些子进程都可以通过这个连接读到数据 ...

  4. Possible MySQL server UUID duplication for server

     在mysql enterprise monitor监控过程中出现这样的event事件,Topic: Possible MySQL server UUID duplication for serv ...

  5. Can‘t connect to local MySQL server through socket ‘/home/mysql/mysql-5.6.33/mysql.sock

    登录MySQL的时候出现这个问题 原因是在 tmp目录下没有mysql.sock这个文件 我们需要创建一个软连接到该目录下 [root@test /]# mysql -u root -p Enter ...

  6. MariaDB: ERROR 2003 (HY000): Can't connect to MySQL server on '127.0.0.1' (111 Connection refused)

    MariaDB : ERROR 2003 (HY000): Can't connect to MySQL server on '127.0.0.1' (111 "Connection ref ...

  7. mysql server远程连接_MySql server:开放mysql远程连接

    一般情况下,mysql的用户是没有远程访问的权限的,因此当程序跟数据库不在同一台服务器上时,我们需要开启mysql的远程访问权限. 目前有两种方法可供选择:改表法和授权法. 改表法: 1.登陆mysq ...

  8. cann't connect to db! mysql!,解决SQL Error: Can't connect to MySQL server on错误

    解决SQL Error: Can't connect to MySQL server on错误 文章来源:传奇帮手游 发布时间:2020-12-02 文章性质:原创文章 今天帮主在群里看到有一个兄弟在 ...

  9. #2002-The server is not responding (or the local MySQL server's socket is not correctly configur

    #2002-The server is not responding (or the local MySQL server's socket is not correctly configured) ...

最新文章

  1. 小麦助教:通过阿里云原生中间件产品组合,加速微服务架构落地
  2. 如何优雅的实现界面跳转 之 统跳协议 - DarwinNativeRouter
  3. 职场老油条靠它升职后:还用Excel手动做报表?想想就可笑
  4. windows 播放MP3音乐
  5. 2018前端开发面试备忘录(1年以上经验初中级别前端开发)-面试篇
  6. [心得]分布式系统概念与设计知识整理
  7. django book 制作
  8. 数据结构与算法 哈希表的特点
  9. 微博情感分析 mysql_利用500万条微博语料对微博评论进行情感分析
  10. vue中实现打包时代码压缩
  11. Schizophrenia Bulletin:未用药精神分裂症患者的纹状体多巴胺与奖赏预测误差信号
  12. wireshark过滤规则
  13. jQuery css和显示隐藏及siblings使用
  14. 能够PING通同网段的节点, 但却PING不通其他网段的所有节点的最可能的原因是
  15. c++和java学哪个好,c++和java区别 学哪个比较好
  16. AI × OCR:腾讯文档表格图像识别技术实践
  17. WebKit、Safari以及SafariViewController
  18. 自动驾驶路径规划——DWA(动态窗口法)
  19. 技术专题:几个子网通过一个公网IP上网的WAYOS设置方法
  20. 自动注册activex控件

热门文章

  1. APP测试 你所不知道的app测试重点 难点
  2. 自动化爬虫selenium基础教程
  3. 浏览器的input禁用输入法
  4. matlab矩阵特征分解,用MATLAB实现矩阵分解
  5. Exchange邮箱的创建和配置
  6. flutter 如何实现上下标效果
  7. meta20 无法安装 google play_不ROOT不刷机,小米手机如何安装谷歌 GMS 三件套
  8. 21分钟Mysql入门教程
  9. 微信公众号的申请以及测试号的申请
  10. (极详细版)python计算分位点方法