当前位置:首页 > 文章列表 > 数据库 > MySQL > MySQL数据库连接异常汇总(值得收藏)

MySQL数据库连接异常汇总(值得收藏)

来源:脚本之家 2023-02-25 08:14:08 0浏览 收藏

本篇文章向大家介绍《MySQL数据库连接异常汇总(值得收藏)》,主要包括异常、MySQL连接,具有一定的参考价值,需要的朋友可以参考一下。

在Centos上部署项目发现一个奇怪的问题,数据库连接一直抛异常。于是花了两个小时搜了各种数据库连接异常导致的原因,最终问题得以解决。同时,把解决过程中搜集到的异常信息汇总一下,当大家遇到类似的问题时,给大家以思路。必须珍藏。

问题现象

先来说说我遇到的问题。项目中遇到的问题很奇怪,在Centos上安装了Mysql数据库,项目使用的是Spring Boot。

项目在本地启动连接服务器数据库正常、本地数据库客户端连接服务器数据库正常、服务器本地连接client连接数据库正常。唯独把项目部署到服务器上启动时抛出异常。

异常信息大概(当时未保留异常信息)如下:

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
 
The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
 at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
 at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
 at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
 at java.lang.reflect.Constructor.newInstance(Unknown Source)
 at com.mysql.jdbc.Util.handleNewInstance(Util.java:425)
 at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:989)
 at com.mysql.jdbc.MysqlIO.(MysqlIO.java:341)
 at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2196)
 at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2229)
 at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2024)
 at com.mysql.jdbc.ConnectionImpl.(ConnectionImpl.java:779)
 at com.mysql.jdbc.JDBC4Connection.(JDBC4Connection.java:47)
 at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
 at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
 at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
 at java.lang.reflect.Constructor.newInstance(Unknown Source)
 at com.mysql.jdbc.Util.handleNewInstance(Util.java:425)
 at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:389)
 at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:330)
 at java.sql.DriverManager.getConnection(Unknown Source)
 at java.sql.DriverManager.getConnection(Unknown Source)
 at com.ad.MysqlDemo.main(MysqlDemo.java:32)
Caused by: java.net.ConnectException: Connection refused: connect
 at java.net.DualStackPlainSocketImpl.connect0(Native Method)
 at java.net.DualStackPlainSocketImpl.socketConnect(Unknown Source)
 at java.net.AbstractPlainSocketImpl.doConnect(Unknown Source)
 at java.net.AbstractPlainSocketImpl.connectToAddress(Unknown Source)
 at java.net.AbstractPlainSocketImpl.connect(Unknown Source)
 at java.net.PlainSocketImpl.connect(Unknown Source)
 at java.net.SocksSocketImpl.connect(Unknown Source)
 at java.net.Socket.connect(Unknown Source)
 at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:211)
 at com.mysql.jdbc.MysqlIO.(MysqlIO.java:300)
 ... 15 more

异常原因

几乎尝试了网络上所有的解决方案均无效。渐渐开始怀疑是JDK在作怪。本地使用的JDK版本是1.8.0_151,服务器使用的是1.8.0.242,理论上是没有影响的。

于是把服务器上的jdk卸载,从官网下载了安装包重新安装了1.8.0_241,数据库连接的问题消失了。

后来仔细一想,不是小版本号的问题,而是安装JDK的版本问题,本机安装的JDK是从Oracle官网下载的,而服务器上存储为了省事直接使用yum命令安装的。而centos上默认给安装了OpenJDK。我们知道,从jdk7之后,JDK和OpenJDK属于两个不同授权协议的版本,而OpenJDK源代码不完整、OpenIDK只包含最精简的JDK。

下面分享一下搜索上述异常过程中发现的其他原因导致类似的异常的情况及解决方案。

sock路径问题

问题现象与上述一样,除了服务器部署应用无法连接服务器之外,其他方式都可以连接数据库。

导致问题的原因是:服务器有两块磁盘,中间执行过mv命令,将数据库的存储内容进行了移动操作,同时修改了datadir指向新的目录。

结果:用JAVA程序本地连接失败,抛出org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Communications link failure 异常。

解决方案:修改了datadir相应配置之后,要核查一下mysql.sock文件路径的配置。默认会在/var/lib/mysql/mysql.sock或/temp/mysql.sock。然后,统一修改所有的端([client]、[mysql]、[mysqld]等)均使用统一路径。

SSL连接问题

如果一次信息中还出现如下异常信息:

javax.net.ssl.SSLHandshakeException: No appropriate protocol (protocol is disabled or cipher suites are inappropriate)
 at sun.security.ssl.Handshaker.activate(Handshaker.java:529)
 at sun.security.ssl.SSLSocketImpl.kickstartHandshake(SSLSocketImpl.java:1492)
 at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1361)
 at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1413)
 at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1397)

则有可能是SSL连接的问题。网络是有朋友升级到jdk1.8之后出现上述异常。

解决方案:删掉SSLv3。在JAVA_HOME/jre/lib/security/java.security文件中找到jdk.tls.disabledAlgorithns=SSLv3,……相关的配置,删掉SSLv3部分。删掉SSLv3就是允许SSL调用。

针对SSL连接的问题,还有一种情况就是Mysql使用SSL连接。关于如何配置可参看该文章:https://www.jb51.net/article/100432.htm

数据库连接超时

这种情况是网上主流的信息,有大量的文章,但往往都没有说明具体的场景:应用程序使用过程中出现类似上述异常,注意这里是使用过程中,而不是启动抛异常。

导致使用过程中出现异常的原因是:Mysql服务器默认的“wait_timeout”是8小时(28800秒),也就是一个connection空闲(没有活动)超过8个小时,Mysql将自动断开该connection。而连接池却认为该连接还是有效的(因为并未校验连接的有效性),当应用申请使用该连接时,就会导致上面的报错。

解决方案:修改my.ini配置,增加超时时间或在连接url中添加“&autoReconnect=true”。

在port=3306下面添加如下配置:

wait_timeout=31536000
interactive_timeout=31536000

然后重启MySQL。

这种情况也有可能是数据库连接池maxIdleTime配置导致的。

  

由于mysql的连接空闲超过8个小时就关闭了,但是连接池却永不丢弃连接,认为该连接还是有效的(因为并未校验连接的有效性),当应用申请使用该连接时,就会导致上面的报错。

解决方法:将value设置为20。

其他原因

当然,关于MySQL连接出现类似异常还有其他很多原因:

  • 数据库账户访问权限问题:指定ip和账户授权;
  • 网络权限问题:防火墙是否开启对应的访问权限;
  • 端口问题:访问的端口是否正确,端口是否开启防火墙权限;
  • 账户密码问题:账户密码错误或账户没有指定ip的访问权限;
  • 数据库驱动问题:数据库驱动与数据库对应版本不匹配。
  • 网络稳定问题:网络不稳定导致的问题。
  • 数据库连接池问题:数据库连接池配置过大,导致mysql默认连接数不够的问题。
  • ipv4与ipv6的问题。

今天关于《MySQL数据库连接异常汇总(值得收藏)》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!

版本声明
本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
MySQL优化SQL语句的技巧MySQL优化SQL语句的技巧
上一篇
MySQL优化SQL语句的技巧
带你了解MySQL中的事件调度器EVENT
下一篇
带你了解MySQL中的事件调度器EVENT
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ljg-skills -
    ljg-skills
    ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
    1839次使用
  • MELO音乐 - AI 音乐生成平台,支持多模态创作能力
    MELO音乐
    MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
    1759次使用
  • UniScribe - AI 免费在线音视频转文字平台
    UniScribe
    UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
    1709次使用
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    1896次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    1885次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码