mysql8小時(shí)空閑后連接超時(shí)的問題
問:怎樣才能解決mysql 8小時(shí)空閑后連接超時(shí)的問題?
答:當(dāng)應(yīng)用程序和數(shù)據(jù)庫建立連接時(shí),如果超過了8個(gè)小時(shí),應(yīng)用程序句不會(huì)去訪問數(shù)據(jù)庫,數(shù)據(jù)庫就會(huì)出現(xiàn)斷掉連接的現(xiàn)象 。這時(shí)再次訪問就會(huì)拋出異常,異常如下:
以下為引用的內(nèi)容:
Communications link failure due to
underlying exception:
** BEGIN NESTED EXCEPTION **
java.io.EOFException
STACKTRACE:
java.io.EOFException
at com.mysql.jdbc.MysqlIO.readFully(MysqlIO.java:1913)
at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:2304)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2803)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1573)
...
一般的解決方法大多是在數(shù)據(jù)庫連接字符串中增加“autoReconnect=true ”選項(xiàng)。但是這只對mysql4以前的版本有效。在最新的mysql中是無效的。其實(shí)要解決這個(gè)問題也有一個(gè)簡單的方法,就是修改mysql的啟動(dòng)參數(shù)。缺省情況下mysql的timeout時(shí)間是28800秒,正好是8小時(shí),增加一個(gè)0就可以了。
同理也可以在" my.ini"文件中增加此參數(shù)。
mysqld-nt --default-table-type=innodb --interactive_timeout=288000
用了以上的方法,就能夠很好的解決連接超時(shí)的問題,提高了mysql數(shù)據(jù)庫的工作效率,大家何樂而不為呢?
【編輯推薦】