解决MySQL报错Lost connection to MySQL server during query

问题描述:

在确保网络没有问题的情况下,服务器正常运行一段时间后,数据库抛出了异常"Lost connection to MySQL server during query",字面意思就是在查询过程中丢失连接到MySQL服务器,抛去网络原因,基本上就是数据库配置项问题。


解决方案:

  1. 检查max_allowed_packet,max_allowed_packet指mysql服务器端和客户端在一次传送数据包的过程当中最大允许的数据包大小。如果超过了设置的最大长度,则会导致数据读写失败。

执行以下SQL查询配置项的值,单位是字节:

sql 复制代码
show VARIABLES like '%max_allowed_packet%';

根据情况将配置项的值改为适合项目的使用大小,以64MB为例子

sql 复制代码
set global max_allowed_packet = 64*1024*1024*;

也可以通过修改配置文件,Linux修改my.cnf 文件,Windows修改 my.ini 文件,推荐通过文件修改,需要重启mysql

sql 复制代码
[mysqld]
max_allowed_packet = 64M

通过命令行修改只能临时生效,如果下次数据库重启后对应的配置就会又复原了,因为重启的时候加载的是配置文件里面的配置项

  1. 检查wait_timeout,wait_timeout 默认是28800秒,即mysql链接在无操作8个小时后被自动关闭,如果服务器长时间处于空闲状态,再次访问mysql数据库的时候,数据库会拒绝访问。

执行以下SQL查询配置,单位毫秒

sql 复制代码
SHOW VARIABLES LIKE 'wait_timeout';

修改参数SQL

sql 复制代码
set global wait_timeout=28800 * 2;

也可以通过修改配置文件,Linux修改my.cnf 文件,Windows修改 my.ini 文件,推荐通过文件修改,需要重启mysql

sql 复制代码
[mysqld]
wait_timeout = 57600
相关推荐
夜泉_ly4 分钟前
MySQL -安装与初识
数据库·mysql
qq_529835351 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New3 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6753 小时前
数据库基础1
数据库
我爱松子鱼4 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo4 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser5 小时前
【SQL】多表查询案例
数据库·sql
Galeoto5 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)5 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231115 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql