解決Java程式連線mysql資料庫出現CommunicationsException: Communications link failure錯誤的問題

阿豪聊乾貨發表於2016-09-17

一、背景

  最近在家裡搗鼓一個公司自己搭建的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驅動的版本。

四、總結

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

相關文章