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

您的位置:首頁技術文章
文章詳情頁

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

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

在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.jb51.net/article/100432.htm。

數據庫連接超時

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

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

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

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

wait_timeout=31536000interactive_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數據庫連接異常的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产一区二区三区不卡视频网站 | 成人av动漫在线观看| 精品女同一区二区三区在线观看| 国产欧美日韩在线一区二区| 亚洲精品一级| 亚洲精品国产日韩| 日韩亚洲精品在线观看| 亚洲二区精品| 亚洲第一区色| 亚洲在线电影| 亚洲视频二区| 欧美精品国产一区| 精品国产一区二区三区av片| 97在线精品| 亚洲国产专区校园欧美| 伊人久久亚洲影院| 亚洲精品三级| 欧美一区成人| 成人精品高清在线视频| 日韩欧美少妇| 黄色免费成人| 深夜福利一区| 青青青国产精品| 麻豆精品视频在线| 性欧美videohd高精| 久久免费大视频| 中文一区一区三区免费在线观 | 国产美女高潮在线观看| 欧美亚洲国产激情| 亚洲精品系列| 精品国产一区二区三区2021| 久久精品亚洲人成影院| 91久久国产| 久久福利一区| 国产精品一区二区99| 特黄毛片在线观看| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲精品免费观看| 欧美91在线| 三级精品视频| 综合激情视频| 精品一区二区三区中文字幕| 一区二区三区四区在线看| 日本在线不卡视频| 国产福利电影在线播放| 噜噜噜躁狠狠躁狠狠精品视频| 国产九一精品| 亚洲国产成人精品女人| 欧美日韩一区二区三区不卡视频 | 精品视频在线一区二区在线| 中文字幕在线免费观看视频| 亚洲黄页一区| 国产精品美女在线观看直播| 免费污视频在线一区| 日本亚洲欧美天堂免费| 精品视频久久| 免费日韩av| 久久香蕉精品香蕉| 国产亚洲激情| 韩国一区二区三区视频| 亚洲欧美日韩精品一区二区 | 日本v片在线高清不卡在线观看| 国产精品对白久久久久粗| 久久精品欧美一区| 国产精品宾馆| 婷婷亚洲五月色综合| 国产精品调教视频| 欧美在线影院| 久久精品国产99国产| 国产日韩专区| 黄色在线观看www| 日本在线视频一区二区| 国产色播av在线| 欧美私人啪啪vps| 欧美天堂亚洲电影院在线观看| 国产精品4hu.www| 99在线|亚洲一区二区| 国产96在线亚洲| 欧美日韩1区2区3区| 亚洲精品一区二区妖精| 国产一区福利| 综合激情在线| 女人av一区| 国产精品99视频| 91午夜精品| 丝袜脚交一区二区| 欧美13videosex性极品| 清纯唯美亚洲综合一区| 狠狠干综合网| 日韩av福利| 欧美成人精品午夜一区二区| 蜜桃久久精品一区二区| 久久久五月天| 精品视频在线观看网站| 欧美日本不卡高清| 亚洲青青久久| 蜜臀久久99精品久久一区二区| 精品三级av| 国产精品一页| 日本不卡视频在线观看| 亚洲在线观看| 香蕉精品视频在线观看| 色偷偷色偷偷色偷偷在线视频| 国产精品久久免费视频| 青青草伊人久久| 日韩有码av| 亚洲一区av| 免费一级片91| 国产精品毛片在线看| 亚洲免费黄色| 激情五月色综合国产精品| 欧美国产另类| 国产精品草草| 美女精品视频在线| 欧美激情五月| 红杏一区二区三区| 精品免费视频| 国产高清视频一区二区| 欧美日本精品| 国产剧情一区二区在线观看| 国产欧美日韩影院| 国产精品99久久久久久董美香| 国产精品v日韩精品v欧美精品网站 | 蜜桃一区二区三区| 国精品产品一区| 欧美aa在线视频| 久久av免费| 日本一区中文字幕| 亚洲另类黄色| 婷婷视频一区二区三区| 亚洲人成在线影院| 日韩精品社区| 久久精品超碰| 国产劲爆久久| 久久精品人人| 麻豆久久久久久| 高清在线一区| 久久亚洲精品中文字幕蜜潮电影| 亚洲夜间福利| 日本欧洲一区二区| 日韩国产在线观看| 国产精品成人一区二区网站软件| 九九九精品视频| 国产高清不卡| 亚洲精品电影| 日本综合视频| 久久影院一区二区三区| 免费看av不卡| 一区二区自拍| 亚洲综合色婷婷在线观看| 日韩精品社区| 九九99久久精品在免费线bt| 国产亚洲一区二区手机在线观看 | 欧洲av不卡| av亚洲免费| 日韩毛片一区| 精品国产美女a久久9999| 日韩视频网站在线观看| 国产精品最新| 日本高清不卡一区二区三区视频| 日韩午夜电影| 日本午夜精品| 国产成年精品| 国产中文一区| 亚洲欧洲av| 捆绑调教美女网站视频一区| 韩国三级一区| 亚洲欧美久久精品| 麻豆视频一区| 99成人在线| 美女在线视频一区| 国内精品99| 欧美一级二级视频| 亚洲精品国产嫩草在线观看| 亚洲专区视频| 成人在线超碰| 午夜在线一区二区| 精品一区二区三区中文字幕 | 日本 国产 欧美色综合| 欧美xxxx性| 蜜臀av免费一区二区三区| 日韩在线网址| av资源中文在线天堂| 日本欧美在线看| 高清一区二区| 在线视频亚洲| 久久精品一区二区国产| 欧美69视频| 国产另类在线| 自由日本语亚洲人高潮| 国产精区一区二区| 亚洲精品在线影院| 中文字幕av一区二区三区四区| 国产一区二区三区亚洲综合| 国产粉嫩在线观看| 亚洲毛片一区| 四虎4545www国产精品 | 国产精品一区二区三区www| 日韩在线二区| 日本一区中文字幕|