当前位置: 首页 > news >正文

.net oracle 连接超时_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.<init>(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.<init>(ConnectionImpl.java:779)
    at com.mysql.jdbc.JDBC4Connection.<init>(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.<init>(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.cnblogs.com/maggieq8324/p/11414889.html。

数据库连接超时

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

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

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

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

wait_timeout=31536000
interactive_timeout=31536000

然后重启MySQL。

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

<!-- 最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->   
<property name="maxIdleTime" value="0"></property> 

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

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

其他原因

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

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

本文首发来自微信公众号:程序新视界。一个软实力、硬技术同步学习的平台。

相关文章:

  • 对校招生培养工作的建议_美团高管对应届生建议:选中行业、选中职业、选中公司...
  • python中最难的是什么_Python 最难的问题你猜是什么?
  • origin数据平滑_Origin使用
  • github python 画图_传说中的画图神器Plotnine,Python中的ggplot2
  • 炉石传说投弹机器人怎么获得_炉石传说:9职业胜率最高卡组推荐 其中这套连99%的玩家都没用过...
  • ios 平滑移动view_在 iOS 中使用 OpenGL ES 实现绘画板
  • 怎么把照片上传到画板_摄影技巧:全黑背景的照片怎么出?怎么拍出高大上的照片...
  • 八皇后时间复杂度 回溯_LeetCode--回溯法心得
  • 运维平台_舜通云-智能光伏运维平台
  • 查询子串_Entity Framework Core Like 查询揭秘
  • 开关电源中的磁性元件书籍_超详细!开关电源电路方案选择指南!
  • 单位和流明_流明 | 你值得这世间所有美好
  • 什么是多态python_Python的多态是什么
  • python谁发明的1003python谁发明的_PAT乙级1003-Python
  • python用户输入10个_2019-07-18 python练习:编写一个程序,要求用户输入10个整数,然后输出其中最大的奇数,如果用户没有输入奇数,则输出一个消息进行说明。...
  • ES6指北【2】—— 箭头函数
  • IE9 : DOM Exception: INVALID_CHARACTER_ERR (5)
  • 时间复杂度分析经典问题——最大子序列和
  • [译]前端离线指南(上)
  • Asm.js的简单介绍
  • ECMAScript 6 学习之路 ( 四 ) String 字符串扩展
  • github从入门到放弃(1)
  • Javascript基础之Array数组API
  • NSTimer学习笔记
  • React-Native - 收藏集 - 掘金
  • SegmentFault 技术周刊 Vol.27 - Git 学习宝典:程序员走江湖必备
  • sessionStorage和localStorage
  • Solarized Scheme
  • Spring思维导图,让Spring不再难懂(mvc篇)
  • -- 查询加强-- 使用如何where子句进行筛选,% _ like的使用
  • 二维平面内的碰撞检测【一】
  • 技术发展面试
  • 使用parted解决大于2T的磁盘分区
  • 它承受着该等级不该有的简单, leetcode 564 寻找最近的回文数
  • 小程序开发之路(一)
  • 用 vue 组件自定义 v-model, 实现一个 Tab 组件。
  • No resource identifier found for attribute,RxJava之zip操作符
  • const的用法,特别是用在函数前面与后面的区别
  • #考研#计算机文化知识1(局域网及网络互联)
  • $emit传递多个参数_PPC和MIPS指令集下二进制代码中函数参数个数的识别方法
  • (04)Hive的相关概念——order by 、sort by、distribute by 、cluster by
  • (39)STM32——FLASH闪存
  • (delphi11最新学习资料) Object Pascal 学习笔记---第2章第五节(日期和时间)
  • (Redis使用系列) Springboot 使用redis实现接口幂等性拦截 十一
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (WSI分类)WSI分类文献小综述 2024
  • (附源码)spring boot车辆管理系统 毕业设计 031034
  • (附源码)基于SSM多源异构数据关联技术构建智能校园-计算机毕设 64366
  • (附源码)计算机毕业设计SSM保险客户管理系统
  • (论文阅读笔记)Network planning with deep reinforcement learning
  • (一)基于IDEA的JAVA基础12
  • (已解决)报错:Could not load the Qt platform plugin “xcb“
  • (译) 函数式 JS #1:简介
  • (转)关于pipe()的详细解析
  • 、写入Shellcode到注册表上线