• 解决:Navicat导入sql脚本时报2006


    目录


    问题复现

            今天在用Navicat 16.0.6导入.sql文件时,运行一半就报错了。错误如下:

    [Err] 2006 - MySQL server has gone away

    原因分析

           sql文件运行出错,第一反应就是文件内容过大,后来发现是navicat软件默认限制了上传sql语句的大小,修改方法很简单。

    解决办法

    1、打开 工具--> 服务器监控-->mysql 

    如下图所示:

    2、选择 变量 ,找到 max_allowed_packect ,修改它的值为 999999448 即可。 

    如下图所示:

    问题小结

            在导入sql脚本过程中出现2006错误的情况很多,以下收集几种情况作为参考:

     1)   MySQL 服务宕了

    判断是否属于这个原因的方法很简单,进入mysql控制台,查看mysql的运行时长或者查看MySQL的报错日志,看看有没有重启的信息—— 如果uptime数值很大,表明mysql服务运行了很久了。说明最近服务没有重启过。 如果日志没有相关信息,也表名mysql服务最近没有重启过,可以继续检查下面几项内容。

    1. mysql> show global status like 'uptime';
    2. +---------------+--------+
    3. | Variable_name | Value  |
    4. +---------------+--------+
    5. | Uptime        | 125695 |
    6. +---------------+--------+
    7. 1 row in set (0.00 sec)

         2)  mysql连接超时

    即某个mysql长连接很久没有新的请求发起,达到了server端的timeout,被server强行关闭。 此后再通过这个connection发起查询的时候,就会报错server has gone away (大部分PHP脚本就是属于此类)

    1. mysql>  show global variables like '%timeout';
    2. +-----------------------------+----------+
    3. | Variable_name               | Value    |
    4. +-----------------------------+----------+
    5. | connect_timeout             | 10       |
    6. | delayed_insert_timeout      | 300      |
    7. | have_statement_timeout      | YES      |
    8. | innodb_flush_log_at_timeout | 1        |
    9. | innodb_lock_wait_timeout    | 50       |
    10. | innodb_rollback_on_timeout  | OFF      |
    11. | interactive_timeout         | 28800    |
    12. | lock_wait_timeout           | 31536000 |
    13. | net_read_timeout            | 30       |
    14. | net_write_timeout           | 60       |
    15. | rpl_stop_slave_timeout      | 31536000 |
    16. | slave_net_timeout           | 60       |
    17. | wait_timeout                | 28800    |
    18. +-----------------------------+----------+
    19. 13 rows in set (0.01 sec)

    wait_timeout 是28800秒,即mysql链接在无操作28800秒后被自动关闭

         3) mysql请求链接进程被主动kill

    这种情况和原因二相似,只是一个是人为一个是MYSQL自己的动作

    1. mysql> show global status like 'com_kill';
    2. +---------------+-------+
    3. | Variable_name | Value |
    4. +---------------+-------+
    5. | Com_kill      | 10     |
    6. +---------------+-------+
    7. 1 row in set (0.00 sec)

         4) Your SQL statement was too large.

    当查询的结果集超过 max_allowed_packet 也会出现这样的报错。定位方法是打出相关报错的语句。 用select * into outfile 的方式导出到文件,查看文件大小是否超过 max_allowed_packet ,如果超过则需要调整参数,或者优化语句。

    1. mysql> show global variables like 'max_allowed_packet';
    2. +--------------------+----------+
    3. | Variable_name      | Value    |
    4. +--------------------+----------+
    5. | max_allowed_packet | 20971520 |
    6. +--------------------+----------+
    7. 1 row in set (0.00 sec)

  • 相关阅读:
    C++ STL
    STM32个人笔记-看门狗
    [附源码]计算机毕业设计springboot大学生考勤管理系统论文
    LeetCode - 二维数组及滚动数组
    数据库查询层级结构
    android反射详解
    Vue中的Ajax②(slot插槽)
    制作一个简单HTML个人网页网页(HTML+CSS)大话西游之大圣娶亲电影网页设计
    PHP Hyperf框架 RPC调用内存泄露
    App支付报错"商家订单参数异常,请重新发起付款"排查流程
  • 原文地址:https://blog.csdn.net/haohaizi_liu/article/details/139446427