解決Java程序連接mysql數據庫出現CommunicationsException: Communications link failure錯誤的問題


一、背景

  最近在家里搗鼓一個公司自己搭建的demo的時候,發現程序一啟動就會出現CommunicationsException: Communications link failure錯誤,經過一番排查最后發現是數據庫url寫錯造成的,這個過程中也對出現這個錯誤的解決思路有了一些自己的理解,現和大家分享。該錯誤的具體信息如下:

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(NativeConstructorAccessorImpl.java:57)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:525)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:404)
    at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:981)
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:339)
    at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2253)
    ......

二、解決問題步驟

1.檢查你的數據庫連接地址(配置文件中的url)是否正確.

2.有可能是由mysql5數據庫的配置引起的。mysql5將其連接的等待時間(wait_timeout)缺省為8小時。在其客戶程序中可以這樣來查看其值: 

mysql > show global variables like 'wait_timeout'; 
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| wait_timeout  | 28800 |
+---------------+-------+
1 row in set (0.00 sec)

28800 seconds,也就是8小時,如果在wait_timeout秒期間內,數據庫連接(java.sql.Connection)一直處於等待狀態,mysql5就將該連接關閉。這時,你的Java應用的連接池仍然合法地持有該連接的引用。當用該連接來進行數據庫操作時,就碰到上述錯誤。

三、解決方式

1.mysql5以前的版本可以直接在jdbc連接url的配置中附加上“autoReconnect=true”。

2.將mysql的全局變量wait_timeout的值修改為最大。查看mysql5的手冊,發現windows和linux下wait_timeout的最大值分別是24天和365天。

 (1).在文件my.ini的最后增加一行:wait_timeout=1814400。(該文件,windows下在mysql的安裝目錄下,linux下位置為/etc/my.ini)

 (2).重啟mysql。

3.如果經過了以上的步驟,你的問題依舊沒有的到解決,則建議你修改下你程序中的mysql驅動的版本。

四、總結

  通過本問題的解決,我們認識到如果碰到問題,首先不要慌,然后從最近的位置進行排查,最后一定能夠完美解決問題。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM