mysql没多久自动断开服务_mysql 长时间没连接了 就会自动断开服务
這是因為mysql 長時間沒連接了 就會自動斷開服務(wù)。 解決辦法 1、首先,下載必須的jar包 dbcp 包,目前版本是1.2.1:http://jakarta.apache.org/commons/ dbcp / pool包,目前版本是1.3:http://jakarta.apache.org/commons/pool/, 如果下載的pool包是1.2的版本,還要下載common-collections包:http://jakarta.apache.org/commons/collections/ 在建立我們自己的數(shù)據(jù)庫連接池時,可以使用xml文件來傳入需要的參數(shù),這里只使用hard code的方式來簡單介紹,所有需要我們自己寫的代碼很少,只要建立一個文件如下: import org.apache.commons. dbcp .BasicDataSource; import org.apache.commons. dbcp .BasicDataSourceFactory; import java.sql.SQLException; import java.sql.Connection; import java.util.Properties; public class ConnectionSource { private static BasicDataSource dataSource = null; public ConnectionSource() { } public static void init() { if (dataSource != null) { try { dataSource.close(); } catch (Exception e) { // } dataSource = null; } try { Properties p = new Properties(); p.setProperty("driverClassName", "oracle.jdbc.driver.OracleDriver"); p.setProperty("url", "jdbc:oracle:thin:@192.168.0.1:1521:testDB"); p.setProperty("password", "scott"); p.setProperty("username", "tiger"); p.setProperty("maxActive", "30"); p.setProperty("maxIdle", "10"); p.setProperty("maxWait", "1000"); p.setProperty(" removeAbandoned ", "false"); p.setProperty("removeAbandonedTimeout", "120"); p.setProperty("testOnBorrow", "true"); p.setProperty("logAbandoned", "true"); dataSource = (BasicDataSource) BasicDataSourceFactory.createDataSource(p); } catch (Exception e) { // } } public static synchronized Connection getConnection() throws SQLException { if (dataSource == null) { init(); } Connection conn = null; if (dataSource != null) { conn = dataSource.getConnection(); } return conn; } } 接下來,在我們的應(yīng)用中,只要簡單地使用ConnectionSource.getConnection()就可以取得連接池中的數(shù)據(jù)庫連接,享受數(shù) 據(jù)庫連接帶給我們的好處了。當(dāng)我們使用完取得的數(shù)據(jù)庫連接后,只要簡單地使用connection.close()就可把此連接返回到連接池中,至于為什 么不是直接關(guān)閉此連接,而是返回給連接池,這是因為 dbcp 使用委派模型來實現(xiàn)Connection接口了。 在使用Properties來創(chuàng)建BasicDataSource時,有很多參數(shù)可以設(shè)置,比較重要的還有: testOnBorrow、testOnReturn、testWhileIdle,他們的意思是當(dāng)是取得連接、返回連接或連接空閑時是否進(jìn)行有效性 驗證(即是否還和數(shù)據(jù)庫連通的),默認(rèn)都為false。所以當(dāng)數(shù)據(jù)庫連接因為某種原因斷掉后,再從連接池中取得的連接,實際上可能是無效的連接了,所以, 為了確保取得的連接是有效的,可以把把這些屬性設(shè)為true。當(dāng)進(jìn)行校驗時,需要另一個參數(shù):validationQuery,對oracle來說,可以 是:SELECT COUNT(*) FROM DUAL,實際上就是個簡單的SQL語句,驗證時,就是把這個SQL語句在數(shù)據(jù)庫上跑一下而已,如果連接正常的,當(dāng)然就有結(jié)果返回了。 還有2個參數(shù):timeBetweenEvictionRunsMillis 和 minEvictableIdleTimeMillis,他們兩個配合,可以持續(xù)更新連接池中的連接對象,當(dāng) timeBetweenEvictionRunsMillis 大于0時,每過timeBetweenEvictionRunsMillis 時間,就會啟動一個線程,校驗連接池中閑置時間超過minEvictableIdleTimeMillis的連接對象。 還有其他的一些參數(shù),可以參考源代碼。 部分參數(shù)簡要說明: removeAbandoned :是否自動回收超時連接 removeAbandonedTimeout:超時時間(以秒數(shù)為單位) rmoveAbandoned=true那么在getNumActive()快要到getMaxActive()的時候,系統(tǒng)會進(jìn)行無效的 Connection的回收,回收的Connection為removeAbandonedTimeout(默認(rèn)300秒)中設(shè)置的秒數(shù)后沒有使用的 Connection logAbandoned:logAbandoned=true的話,將會在回收事件后,在log中打印出回收Connection的錯誤信息,包括在哪個地方用了Connection卻忘記關(guān)閉了,在調(diào)試的時候很有用。 maxWait:超時等待時間以毫秒為單位 maxIdle:最大空閑連接 minIdle:最小空閑連接 maxActive:最大連接數(shù) testOnBorrow、testOnReturn、testWhileIdle、validationQuery:上面有介紹 另外很重要的一點是每次連接使用完了不要忘了調(diào)用connection.close()使連接返回到連接池
總結(jié)
以上是生活随笔為你收集整理的mysql没多久自动断开服务_mysql 长时间没连接了 就会自动断开服务的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: word+增加水印+java_为Word
- 下一篇: 在建工程直接费用化_威县垃圾发电在建项目