日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL數(shù)據(jù)庫連接異常匯總(值得收藏)

瀏覽:177日期:2023-10-13 09:25:19

在Centos上部署項目發(fā)現(xiàn)一個奇怪的問題,數(shù)據(jù)庫連接一直拋異常。于是花了兩個小時搜了各種數(shù)據(jù)庫連接異常導(dǎo)致的原因,最終問題得以解決。同時,把解決過程中搜集到的異常信息匯總一下,當(dāng)大家遇到類似的問題時,給大家以思路。必須珍藏。

問題現(xiàn)象

先來說說我遇到的問題。項目中遇到的問題很奇怪,在Centos上安裝了Mysql數(shù)據(jù)庫,項目使用的是Spring Boot。

項目在本地啟動連接服務(wù)器數(shù)據(jù)庫正常、本地數(shù)據(jù)庫客戶端連接服務(wù)器數(shù)據(jù)庫正常、服務(wù)器本地連接client連接數(shù)據(jù)庫正常。唯獨把項目部署到服務(wù)器上啟動時拋出異常。

異常信息大概(當(dāng)時未保留異常信息)如下:

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

異常原因

幾乎嘗試了網(wǎng)絡(luò)上所有的解決方案均無效。漸漸開始懷疑是JDK在作怪。本地使用的JDK版本是1.8.0_151,服務(wù)器使用的是1.8.0.242,理論上是沒有影響的。

于是把服務(wù)器上的jdk卸載,從官網(wǎng)下載了安裝包重新安裝了1.8.0_241,數(shù)據(jù)庫連接的問題消失了。

后來仔細一想,不是小版本號的問題,而是安裝JDK的版本問題,本機安裝的JDK是從Oracle官網(wǎng)下載的,而服務(wù)器上存儲為了省事直接使用yum命令安裝的。而centos上默認給安裝了OpenJDK。我們知道,從jdk7之后,JDK和OpenJDK屬于兩個不同授權(quán)協(xié)議的版本,而OpenJDK源代碼不完整、OpenIDK只包含最精簡的JDK。

下面分享一下搜索上述異常過程中發(fā)現(xiàn)的其他原因?qū)е骂愃频漠惓5那闆r及解決方案。

sock路徑問題

問題現(xiàn)象與上述一樣,除了服務(wù)器部署應(yīng)用無法連接服務(wù)器之外,其他方式都可以連接數(shù)據(jù)庫。

導(dǎo)致問題的原因是:服務(wù)器有兩塊磁盤,中間執(zhí)行過mv命令,將數(shù)據(jù)庫的存儲內(nèi)容進行了移動操作,同時修改了datadir指向新的目錄。

結(jié)果:用JAVA程序本地連接失敗,拋出org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Communications link failure 異常。

解決方案:修改了datadir相應(yīng)配置之后,要核查一下mysql.sock文件路徑的配置。默認會在/var/lib/mysql/mysql.sock或/temp/mysql.sock。然后,統(tǒng)一修改所有的端([client]、[mysql]、[mysqld]等)均使用統(tǒng)一路徑。

SSL連接問題

如果一次信息中還出現(xiàn)如下異常信息:

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連接的問題。網(wǎng)絡(luò)是有朋友升級到j(luò)dk1.8之后出現(xiàn)上述異常。

解決方案:刪掉SSLv3。在JAVA_HOME/jre/lib/security/java.security文件中找到j(luò)dk.tls.disabledAlgorithns=SSLv3,……相關(guān)的配置,刪掉SSLv3部分。刪掉SSLv3就是允許SSL調(diào)用。

針對SSL連接的問題,還有一種情況就是Mysql使用SSL連接。關(guān)于如何配置可參看該文章:https://www.jb51.net/article/100432.htm。

數(shù)據(jù)庫連接超時

這種情況是網(wǎng)上主流的信息,有大量的文章,但往往都沒有說明具體的場景:應(yīng)用程序使用過程中出現(xiàn)類似上述異常,注意這里是使用過程中,而不是啟動拋異常。

導(dǎo)致使用過程中出現(xiàn)異常的原因是:Mysql服務(wù)器默認的“wait_timeout”是8小時(28800秒),也就是一個connection空閑(沒有活動)超過8個小時,Mysql將自動斷開該connection。而連接池卻認為該連接還是有效的(因為并未校驗連接的有效性),當(dāng)應(yīng)用申請使用該連接時,就會導(dǎo)致上面的報錯。

解決方案:修改my.ini配置,增加超時時間或在連接url中添加“&autoReconnect=true”。

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

wait_timeout=31536000interactive_timeout=31536000

然后重啟MySQL。

這種情況也有可能是數(shù)據(jù)庫連接池maxIdleTime配置導(dǎo)致的。

<!-- 最大空閑時間,60秒內(nèi)未使用則連接被丟棄。若為0則永不丟棄。Default: 0 --> <property name='maxIdleTime' value='0'></property>

由于mysql的連接空閑超過8個小時就關(guān)閉了,但是連接池卻永不丟棄連接,認為該連接還是有效的(因為并未校驗連接的有效性),當(dāng)應(yīng)用申請使用該連接時,就會導(dǎo)致上面的報錯。

解決方法:將value設(shè)置為20。

其他原因

當(dāng)然,關(guān)于MySQL連接出現(xiàn)類似異常還有其他很多原因:

數(shù)據(jù)庫賬戶訪問權(quán)限問題:指定ip和賬戶授權(quán); 網(wǎng)絡(luò)權(quán)限問題:防火墻是否開啟對應(yīng)的訪問權(quán)限; 端口問題:訪問的端口是否正確,端口是否開啟防火墻權(quán)限; 賬戶密碼問題:賬戶密碼錯誤或賬戶沒有指定ip的訪問權(quán)限; 數(shù)據(jù)庫驅(qū)動問題:數(shù)據(jù)庫驅(qū)動與數(shù)據(jù)庫對應(yīng)版本不匹配。 網(wǎng)絡(luò)穩(wěn)定問題:網(wǎng)絡(luò)不穩(wěn)定導(dǎo)致的問題。 數(shù)據(jù)庫連接池問題:數(shù)據(jù)庫連接池配置過大,導(dǎo)致mysql默認連接數(shù)不夠的問題。 ipv4與ipv6的問題。

以上就是MySQL數(shù)據(jù)庫連接異常匯總的詳細內(nèi)容,更多關(guān)于MySQL數(shù)據(jù)庫連接異常的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩高清欧美激情| 高清日韩欧美| 欧美日韩第一| 久久久久国产精品一区三寸| 日韩一区二区中文| 欧美日韩在线观看视频小说| 午夜国产一区二区| 亚欧成人精品| 国产精品成人**免费视频| 精品视频一二| 欧美韩日一区| 激情欧美国产欧美| 中文字幕一区二区三区日韩精品 | 久久国产日本精品| 黑丝美女一区二区| 综合亚洲自拍| 麻豆视频在线观看免费网站黄 | 日韩精品一二三| 亚洲a级精品| 国产激情精品一区二区三区| bbw在线视频| 久久大逼视频| 久久的色偷偷| 99久久夜色精品国产亚洲狼 | 青青青国产精品| 欧美国产偷国产精品三区| 黄色在线一区| 久久国产视频网| 久久美女性网| 婷婷五月色综合香五月| 精品久久中文| 亚洲专区一区| 国产成人精品一区二区三区在线| 日韩精品久久久久久久电影99爱 | 在线亚洲成人| 麻豆91在线播放| 欧美精品一区二区三区精品| 久久国产精品色av免费看| 国产精品成久久久久| 中文在线不卡| 久久中文精品| 欧美一级专区| a国产在线视频| 欧美亚洲免费| 亚洲欧美综合| 精品一区二区三区的国产在线观看| 在线国产一区| 精品视频自拍| 色综合视频一区二区三区日韩 | 一区二区视频欧美| 久久伊人亚洲| 亚洲一区二区三区无吗| 成人在线黄色| 91成人在线精品视频| 亚洲男女av一区二区| 精品色999| 日韩精品欧美大片| 亚洲综合日韩| 久久婷婷一区| 久久亚洲国产精品尤物| 亚洲丝袜啪啪| 国产二区精品| 国产日韩电影| 另类小说一区二区三区| 日韩精品91亚洲二区在线观看| 婷婷六月综合| 国产精品高颜值在线观看| 日本伊人午夜精品| 在线视频亚洲| 午夜电影亚洲| 久久网站免费观看| 9999国产精品| 福利一区二区三区视频在线观看| 欧美天堂一区| 伊人久久大香伊蕉在人线观看热v| 亚洲成人精品| аⅴ资源天堂资源库在线| 久久尤物视频| 久久国际精品| 国产伦理久久久久久妇女| 亚洲一区二区三区无吗| 激情视频一区二区三区| 黄毛片在线观看| 久久一区精品| 激情不卡一区二区三区视频在线| 国产精品毛片aⅴ一区二区三区| 三级久久三级久久久| 亚洲久久视频| 亚洲精品美女91| 亚洲精品乱码久久久久久蜜桃麻豆| 美女精品一区| 日韩精品一二三| 久久午夜精品| 在线精品国产亚洲| 在线一区二区三区视频| 亚洲日本国产| 婷婷综合一区| 97久久超碰| 国产精品任我爽爆在线播放| 国产欧美日韩一区二区三区四区 | 激情综合婷婷| 激情国产在线| 成人精品亚洲| 99久久久久久中文字幕一区| 91精品综合| 91久久久精品国产| 妖精视频成人观看www| 男女男精品视频网| 日韩在线播放一区二区| 天堂av一区| 国产精品第十页| av资源新版天堂在线| 久久精品国产大片免费观看| 免费国产自久久久久三四区久久 | 欧美一区二区三区激情视频| 99久久夜色精品国产亚洲狼 | 国产欧美日韩精品一区二区三区| 国产精品videosex极品| 精品日韩一区| 91精品啪在线观看国产18| 国产农村妇女精品一区二区| 四虎国产精品免费久久| 久久不见久久见国语| 四季av一区二区凹凸精品| 亚洲无线一线二线三线区别av| 国产亚洲精品久久久久婷婷瑜伽| 亚洲精品在线a| 久久的色偷偷| 国产精品久久久久av电视剧| 中文一区在线| 国产精品调教视频| 久久久精品五月天| 亚洲ww精品| 中文字幕在线视频久| 日韩中文字幕区一区有砖一区| 国产精品美女午夜爽爽| 香蕉国产精品| 国产麻豆一区二区三区精品视频| 欧美日韩免费看片| 美国欧美日韩国产在线播放| 青草av.久久免费一区| 日韩美女一区二区三区在线观看| 免费人成精品欧美精品| 欧美日一区二区在线观看| 国产91在线播放精品| aa国产精品| 精品视频在线一区二区在线| 亚洲一区日韩在线| 麻豆视频一区| 日本 国产 欧美色综合| 理论片午夜视频在线观看| 亚洲我射av| 中文字幕在线官网| 97久久精品| 黄色亚洲大片免费在线观看| 精品国产欧美日韩一区二区三区| 蜜桃av一区二区三区电影| 久久人人97超碰国产公开结果| 亚洲免费观看高清完整版在线观| 91综合网人人| 日本99精品| 蜜臀av免费一区二区三区| 国产极品模特精品一二| 久久久久久久久丰满| 国产精品一级| 在线日韩成人| 免费av一区二区三区四区| 精品国产亚洲一区二区在线观看| 日韩中文字幕麻豆| 久久亚洲精品中文字幕蜜潮电影| 国产精品宾馆| 日韩高清不卡一区二区| 欧美日韩免费观看一区=区三区| 国产精品香蕉| 免费在线观看精品| 99久久久久国产精品| 福利精品一区| 国产精品115| 日韩高清不卡一区| 亚洲日韩中文字幕一区| 美女黄网久久| 99在线观看免费视频精品观看| 国产一区三区在线播放| 久久精品99国产精品日本| 免费在线视频一区| 在线视频亚洲| 美女少妇全过程你懂的久久| 日韩欧美在线中字| 久久69成人| 日本三级亚洲精品| 日韩精品视频在线看| 日韩一区二区三区高清在线观看| 日韩视频在线一区二区三区 | 日韩久久电影| 精品国产三区在线| 国产亚洲久久| 日韩激情一二三区| 国产亚洲毛片| 亚洲激情久久| 亚洲夜间福利|