数据库炸了----我就重启了一下啊(Communications link failure)
重启数据库后,数据库大部分时间连不上了;连续请求不会报错,请求间隔时间稍微长一点就会报错
报错如图:
com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure
The last packet successfully received from the server was 7,008 milliseconds ago. The last packet sent successfully to the server was 0 milliseconds ago.
这里的意思是 7,008毫秒前创建的连接,现在不可用了。有的报错这个时间是很大的。
上网查资料(也问了老大,老大一看报错,说这样改最快,我追问了一下,老大说了下全局变量和会话变量的作用范围,和我后面找到的答案一样):
test-on-borrow: true #申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
test-on-return: true #归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
把这两个配置配上就能解决问题!!!但是,本来为了性能,这两个配置默认是false。问题的关键可能不在这,我就重启了一下mysql,本来是好好的,就是重启出了问题的。
继续查原因
1,查看mysql系统配置参数:
show VARIABLES like '%timeout%'
发现wait_timeout和interactive_timeout都是28800,8小时;并无异常
wait_timeout:针对非交互式连接,通过jdbc连接数据库是非交互式连接
interactive_timeout:针对交互式连接,通过mysql客户端连接数据库是交互式连接
2,查看mysql连接情况:
show processlist; 只展示100个连接
show full processlist; 展示所有连接
查看连接54个,还行,无异常
3,继续上网查资料:
于是忽找到了这篇文章:https://baijiahao.baidu.com/s?id=1642208511147231446&wfr=spider&for=pc
4,查看show status
Abort_clients表示客户端没有正确的关闭连接,而被终止的连接数,引起的原因:
a.客户端程序退出之前未调用mysql_close()来关闭mysql连接
b.客户端的休眠时间超过了mysql系统变量waittimeout和interactivetimeout的值,导致连接被mysql进程终止
c.客户端程序在数据传输过程中突然结束
有10万连接被异常中断!!!
5,查看mysql全局变量:
这里一个容易把人搞蒙的地方是如果查询时使用的是show variables的话,会发现没什么问题,这是因为单纯使用show variables的话就等同于使用的是show session variables,查询的是会话变量,只有使用show global variables,查询的才是全局变量。
上面看到两个超时时间都一样,是因为查的是当前会话的连接 的超时时间,当然是interactivetimeout和waittimeout一样,都是8小时,所以没发现问题。【一定要搞清楚每个命令的真实含义,不然只能抓耳挠腮了】
查看全局配置:
show GLOBAL VARIABLES like '%timeout%'
果然,wait_timeout 是5秒,5秒后mysql连接就会断开导致报错。
再去看了下配置文件:石锤了,配置文件中的wait_timeout 被人修改成了5秒。
interactive_timeout/wait_timeout:交互式和非交互式链接的超时设置,防止客户端长时间链接数据库,什么都不做处于sleep状态,强制关闭长时间的sleep链接。默认情况先两值的都为28800(8h)
6,真相大白:
wait_timeout被设置成了5秒,所以,所有的连接5秒后会被自动关闭,再次使用这个过期的连接就会报错
其中wait_timeout就是负责超时控制的变量,其时间默认长度为28800s,就是8个小时,那么就是说MySQL的服务会在操作间隔8小时后断开,需要再次重连;不知道是谁把他设置成了5秒。重启之后导致数据库连不上,一直报错。
那有人要问了,为什么重启了,出现了问题,原来怎么好好的?
这是一个好问题,我开始也百思不得其解,后来终于弄清楚了:
这是因为mysql的全局配置被修改了,重启mysql前这个配置生效的值并不是5秒。
使用 set global wait_timeout=28800就可以修改mysql全局变量。修改完后就不会再报错了。
不过这样修改不会一劳永逸,如果再次重启mysql,就会重新出现上面的问题。
整个过程应该是这样:第一次安装完mysql后,有人修改了配置文件中的wait_timeout参数为5秒,之后,这个参数又被修改了,这次是用命令set global wait_timeout=xxx,设置这个参数的全局配置为xxx秒(默认是8小时),一直稳定运行到现在。然后我重启了mysql,wait_timeout这个配置就恢复成了5秒,问题出现。
7、后记:
这是一个mysql的基础问题。基础太差导致排查问题用了很长时间。但凡一个科班出身都知道这个。
mysql 版本:5.6.44
试了下5.7.25-log查看命令结果就不一样了
数据库炸了----我就重启了一下啊(Communications link failure)的更多相关文章
- 解决Java程序连接mysql数据库出现CommunicationsException: Communications link failure错误的问题
一.背景 最近在家里捣鼓一个公司自己搭建的demo的时候,发现程序一启动就会出现CommunicationsException: Communications link failure错误,经过一番排 ...
- com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure 数据库报错
-- 查询mysql 数据库链接空闲时间持有最大空闲时间,单位为秒 SHOW VARIABLES WHERE VAriable_name = 'interactive_timeout'; -- 会出现 ...
- 应用端连接MySQL数据库报Communications link failure
事情的起因: 某项目的开发同学突然Q我们组的某同学,要求我们调整MySQL的连接等待超时参数wait_timeout.要求我们从28800s调整到31536000s(也就是一年) 应用端测试环境的to ...
- 数据库炸了——是谁动了我的wait_timeout
1.起因 隐约听到坐在我对面的测试说测试环境的接口有问题 他们一番商讨后,朝我这边反馈说,现在测试环境的接口报504 我条件反射的回了句那是接口超时,再多试几次(测试环境的性能比较差,尤其是数据库,经 ...
- Quartz动态修改数据库cronExpression(无须重启服务器即可更改定时时间)
quartz通过动态设置配置文件确实可以实现与数据库的同步,但现实开发上线后我们基本是不会对配置文件等进行变动,因为重启一次服务器所需的成本太多. 这时,就需要我们仅仅修改数据库就能实现动态的更新定时 ...
- ORACLE数据库的关闭与重启
一.关闭数据库 1.SHUTDOWN IMMEDIATE 这是我们常用的一种关闭数据库的方式,想很快地关闭数据库,但又想让数据库干净的关闭,常采用这种方式. 当前正在被Oracle处理的SQL语句立即 ...
- Communications link failure--分析之(JDBC的多种超时情况)
本文是针对特定的情景下的特定错误,不是所有Communications link failure错误都是这个引起的,重要的区分特点是:程序是不是在卡主后两个小时(服务器的设置)后程序才感知到,才抛出了 ...
- centos7环境配置haproxy实现mysql数据库和redis代理服务器
centos7环境配置haproxy实现mysql数据库代理 我们通常会碰到这样的业务场景: b主机和c数据库在同一个内网,a主机不能直接访问c数据库,我们可以通过在b主机上搭建代理让a访问c数据库, ...
- 在远程连接mysql数据库出现问题怎么办
远程连接mysql数据库报“Communications link failure...”错误 今天在用myEclipse连接时提示:Communications link failure,Last ...
随机推荐
- Oracle部署迁移手册
第1章 安装准备 1.1 安装环境 操作系统:Redhat6.5 x64 32核CPU 62G内存 系统盘300G 数据磁盘3T Oracle软件:Oracle Database 11g Enterp ...
- c++ class里面成员和分配内存问题
慢慢开始学c++啦,记录学习的大体过程 class中神奇的内存(sizeof) 1.内存补齐 便于管理类(生成的对象)的内存,类总内存总是为最大成员字节大小的倍数,不足的会进行内存补齐 类的整体内存就 ...
- NLP与深度学习(六)BERT模型的使用
1. 预训练的BERT模型 从头开始训练一个BERT模型是一个成本非常高的工作,所以现在一般是直接去下载已经预训练好的BERT模型.结合迁移学习,实现所要完成的NLP任务.谷歌在github上已经开放 ...
- Serverless 的初心、现状和未来
作者 | 不瞋 导读:Serverless 是如何产生的?当前有哪些落地场景?Serverless 的未来又将如何?本文分享了阿里云高级技术专家不瞋对于 Serverless 的看法,回顾其发展历程, ...
- WinForm 控件 DataGridView 常用操作
1.取消列自动生成 在窗体load事件里面设置表格dataGridView的AutoGenerateColumns为 false dataGridView.AutoGenerateColumns = ...
- Data Management Tools(数据管理工具)《二》
(数据管理工具)<二> 点击跳转(数据管理工具)<一> 16.打包 # Process: 共享包 arcpy.SharePackage_management("&qu ...
- 从 MVC 到使用 ASP.NET Core 6.0 的最小 API
从 MVC 到使用 ASP.NET Core 6.0 的最小 API https://benfoster.io/blog/mvc-to-minimal-apis-aspnet-6/ 2007 年,随着 ...
- MyBatis 中两表关联查询MYSQL (14)
MyBatis 中两表关联查询MYSQL 1.创建数据库表语句 2.插入测试数据 3.pom文件内容 <?xml version="1.0" encoding="U ...
- LuckySheet一款在线Excel使用心得
1.LuckySheet简介 Luckysheet ,是一款国产的纯JS实现的类似excel的在线表格,功能强大.配置简单.完全开源. 开源地址 https://gitee.com/mengshuke ...
- C#特性知识图谱-二、事件
C#特性知识图谱-二.事件 二.事件 在事件驱动的软件系统中,符合某种预设条件的情形出现是,一个事件就会被触发. 2.1 事件三要素 事件源:激发事件的对象 事件信息:事件本身说携带的信息 事件响应者 ...