一、背景
最近在家裡搗鼓一個公司自己搭建的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驅動的版本。
四、總結
通過本問題的解決,我們認識到如果碰到問題,首先不要慌,然後從最近的位置進行排查,最後一定能夠完美解決問題。