MySQL数据库连接异常汇总(值得收藏)
在Centos上部署项目发现一个奇怪的问题,数据库连接一直抛异常。于是花了两个小时搜了各种数据库连接异常导致的原因,最终问题得以解决。,把解决过程中搜集到的异常信息汇总一下,当大家遇到类似的问题时,给大家以思路。必须珍藏。
问题现象
先来说说我遇到的问题。项目中遇到的问题很奇怪,在Centos上安装了Mysql数据库,项目使用的是Spring Boot。
项目在本地启动连接服务器数据库正常、本地数据库客户端连接服务器数据库正常、服务器本地连接client连接数据库正常。唯独把项目部署到服务器上启动时抛出异常。
异常信息大概(当时未保留异常信息)如下
.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
The last packet sent suessfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
at sun.reflect.NativeConstructorAessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAessorImpl.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at .mysql.jdbc.Util.handleNewInstance(Util.java:425)
at .mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:989)
at .mysql.jdbc.MysqlIO.<init>(MysqlIO.java:341)
at .mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2196)
at .mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2229)
at .mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2024)
at .mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:779)
at .mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47)
at sun.reflect.NativeConstructorAessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAessorImpl.newInstance(Unknown Source)
at sun.reflect.DelegatingConstructorAessorImpl.newInstance(Unknown Source)
at java.lang.reflect.Constructor.newInstance(Unknown Source)
at .mysql.jdbc.Util.handleNewInstance(Util.java:425)
at .mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:389)
at .mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:330)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at .ad.MysqlDemo.main(MysqlDemo.java:32)
Caused by: java..ConnectException: Connection refused: connect
at java..DualStackPlainSocketImpl.connect0(Native Method)
at java..DualStackPlainSocketImpl.socketConnect(Unknown Source)
at java..AbstractPlainSocketImpl.doConnect(Unknown Source)
at java..AbstractPlainSocketImpl.connectToAddress(Unknown Source)
at java..AbstractPlainSocketImpl.connect(Unknown Source)
at java..PlainSocketImpl.connect(Unknown Source)
at java..SocksSocketImpl.connect(Unknown Source)
at java..Socket.connect(Unknown Source)
at .mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:211)
at .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。
狼蚁网站SEO优化分享一下搜索上述异常过程中发现的其他原因导致类似的异常的情况及解决方案。
sock路径问题
问题现象与上述一样,除了服务器部署应用无法连接服务器之外,其他方式都可以连接数据库。
导致问题的原因是服务器有两块磁盘,中间执行过mv命令,将数据库的存储内容进行了移动操作,修改了datadir指向新的目录。
结果用JAVA程序本地连接失败,抛出.apache.mons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Communications link failure 异常。
解决方案修改了datadir相应配置之后,要核查一下mysql.sock文件路径的配置。默认会在/var/lib/mysql/mysql.sock或/temp/mysql.sock。然后,统一修改所有的端([client]、[mysql]、[mysqld]等)均使用统一路径。
SSL连接问题
如果一次信息中还出现如下异常信息
javax..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连接。关于如何配置可参看该文章。
数据库连接超时
这种情况是网上主流的信息,有大量的文章,但往往都没有说明具体的场景应用程序使用过程中出现类似上述异常,注意这里是使用过程中,而不是启动抛异常。
导致使用过程中出现异常的原因是Mysql服务器默认的“wait_timeout”是8小时(28800秒),也就是一个connection空闲(没有活动)超过8个小时,Mysql将自动断开该connection。而连接池却认为该连接还是有效的(因为并未校验连接的有效性),当应用申请使用该连接时,就会导致上面的报错。
解决方案修改my.ini配置,增加超时时间或在连接url中添加“&autoReconnect=true”。
在port=3306狼蚁网站SEO优化添加如下配置
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的问题。
以上就是MySQL数据库连接异常汇总的详细内容,更多关于MySQL数据库连接异常的资料请关注狼蚁SEO其它相关文章!
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南