首先介紹一個(gè)JDBC參數(shù)InactiveConnectionTImeout,該參數(shù)用于強(qiáng)制回收那些被泄露的連接(長(zhǎng)時(shí)間不使用的連接、未被程序正確釋放的連接),避免連接池因?yàn)樾孤秾?dǎo)致無(wú)連接可用。當(dāng)然該參數(shù)只是起輔助作用,解決問(wèn)題知道還是在于完善應(yīng)用程序。
本文和該參數(shù)有關(guān),早期的8.1\9.2中,設(shè)定該參數(shù)時(shí),定時(shí)器(內(nèi)部的連接池維護(hù)Task)只會(huì)清理那些長(zhǎng)期未被使用的空閑連接(從名字上可以看出來(lái)),即對(duì)于運(yùn)行一個(gè)長(zhǎng)時(shí)間執(zhí)行SQL的連接而言,它是不受影響的。但不知道從10.3哪個(gè)版本開(kāi)始(我測(cè)試的是10.3.5),該參數(shù)對(duì)于長(zhǎng)時(shí)間執(zhí)行SQL的連接也進(jìn)行強(qiáng)制回收了(這個(gè)比較不合理,雖然對(duì)于正在執(zhí)行的Tx影響不大)。Debug了一下,發(fā)現(xiàn)SQL執(zhí)行時(shí)間大于4*InactiveConnectionTimeout時(shí),這個(gè)SQL執(zhí)行完成時(shí),會(huì)出現(xiàn) <BEA-001153> <Forcibly releasing inactive connection "
weblogic.jdbc.wrapper.PoolConnection_oracle_jdbc_driver_T4CConnection@1" back into the connection pool "TestDS", currently reserved by: java.lang.Exception這樣的錯(cuò)誤。
//該線程為內(nèi)部Task執(zhí)行線程,該線程目前處于被阻塞狀態(tài),等待SQL執(zhí)行結(jié)束后回收連接
"[STUCK] ExecuteThread: '20' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon prio=2 tid=0x2c4d3400 nid=0x1a14 waiting for monitor entry [0x
319bf000]
java.lang.Thread.State: BLOCKED (on object monitor)
at oracle.jdbc.driver.PhysicalConnection.rollback(PhysicalConnection.java:3896)
- waiting to lock <0x0e6191d8> (a oracle.jdbc.driver.T4CConnection)
at weblogic.jdbc.wrapper.Connection.forcedCleanup(Connection.java:156)
at weblogic.common.resourcepool.ResourcePoolImpl.timeoutInactiveResources(ResourcePoolImpl.java:1955)
at weblogic.common.resourcepool.ResourcePoolImpl.access$8(ResourcePoolImpl.java:1916)
at weblogic.common.resourcepool.ResourcePoolImpl$ResourcePoolMaintanenceTask.timerExpired(ResourcePoolImpl.java:2680)
at weblogic.timers.internal.TimerImpl.run(TimerImpl.java:273)
at weblogic.work.SelfTuningWorkManagerImpl$WorkAdapterImpl.run(SelfTuningWorkManagerImpl.java:528)
at weblogic.work.ExecuteThread.execute(ExecuteThread.java:209)
at weblogic.work.ExecuteThread.run(ExecuteThread.java:178)
//該線程為應(yīng)用執(zhí)行線程,目前該線程SQL正在運(yùn)行,他阻塞(阻塞對(duì)象為T(mén)4CConnection)了內(nèi)部Task執(zhí)行線程
"[STUCK] ExecuteThread: '0' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon prio=2 tid=0x2c7b4c00 nid=0x1100 runnable [0x2cf7e000]
java.lang.Thread.State: RUNNABLE
at java.net.SocketInputStream.socketRead0(Native Method)
......
at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1315)
at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3576)
at oracle.jdbc.driver.OraclePreparedStatement.execute(OraclePreparedStatement.java:3677)
- locked <0x0e6191d8> (a oracle.jdbc.driver.T4CConnection)
at oracle.jdbc.driver.OraclePreparedStatementWrapper.execute(OraclePreparedStatementWrapper.java:1374)
at weblogic.jdbc.wrapper.PreparedStatement.execute(PreparedStatement.java:102)
at com.bea.cs.test.jdbc.DriverTest.inactiveTimeoutTest(DriverTest.java:537)
at jsp_servlet.__ds._jspService(__ds.java:86)
從上面的線程堆??梢钥吹?,內(nèi)部Task線程正在調(diào)用connection的rollback,即回滾連接上的本地事務(wù)。如果應(yīng)用線程上使用的連接設(shè)為auto commit的話,該SQL執(zhí)行不會(huì)被rollback,否則該SQL雖然執(zhí)行完成也會(huì)被rollback調(diào)(全局事務(wù)中,某個(gè)事務(wù)分支使用的連接一定是非auto commit的),所以該問(wèn)題對(duì)涉及全局事務(wù)的應(yīng)用影響比較大。
下面我們?cè)诳纯催B接被回收的時(shí)間點(diǎn)為什么會(huì)出現(xiàn)在3-4個(gè)InactiveConnectionTimeout之間。當(dāng)內(nèi)部Task執(zhí)行,發(fā)現(xiàn)到了InactiveConnectionTimeout時(shí)間點(diǎn)后,它會(huì)調(diào)用timeoutInactiveResources()方法開(kāi)始進(jìn)行連接清理。那么為什么正在執(zhí)行SQL的連接會(huì)被標(biāo)志為非活動(dòng)連接呢?這里涉及連接狀態(tài)的三個(gè)標(biāo)志位,分別為:conn_in_use,connUsed,hang_state,這三個(gè)標(biāo)志位是其中的關(guān)鍵(getUsed()和setUsed()方法中會(huì)進(jìn)行標(biāo)志位操作及讀取,如果對(duì)于某個(gè)連接getUsed()返回false的話,該連接會(huì)被清理)。下面我們看看其中標(biāo)志位的變化過(guò)程: SQL開(kāi)始執(zhí)行時(shí),preInvokeHandler會(huì)被這三個(gè)標(biāo)志位進(jìn)行設(shè)定。
初始值如下:
conn_in_use-->true
hang_state-->conn_state_in_use
connUsed-->true
第一次InactiveConnectionTimeout檢查,getUsed返回true,同時(shí)調(diào)用setUsed(false),標(biāo)志位變化如下:
conn_in_use-->true
hang_state-->conn_state_idle_suspect
connUsed-->true
第二次InactiveConnectionTimeout檢查,getUsed返回true,同時(shí)調(diào)用setUsed(false),標(biāo)志位變化如下:
conn_in_use-->false
hang_state-->conn_state_hang_suspect
connUsed-->false
第三次InactiveConnectionTimeout檢查,getUsed返回true,
hang_state-->conn_state_in_use(從conn_state_hang_suspect變成conn_state_in_use)
同時(shí)調(diào)用setUsed(false),標(biāo)志位變化如下:
conn_in_use-->false
connUsed-->false
hang_state-->conn_state_idle_suspect(從conn_state_in_use變成conn_state_idle_suspect)
第四次InactiveConnectionTimeout檢查,getUsed返回false,開(kāi)始回收該連接。
從上面的變化時(shí)間點(diǎn)可以看到從第一次到第四次檢查經(jīng)歷了完整的3個(gè)InactiveConnectionTimout周期,而從SQL執(zhí)行到第一次檢查點(diǎn),這個(gè)時(shí)間小于一個(gè)InactiveConnectionTimeout,所以連接開(kāi)始被回收的時(shí)間點(diǎn)介于3-4個(gè)InactiveConnectionTimeout之間。
posted @
2013-10-10 16:18 走走停停又三年 閱讀(7662) |
評(píng)論 (1) |
編輯 收藏
摘要: Weblogic10.3.0, connection pool, disable, Weblogic10.3.4, weblogic.resourcepool.max_test_wait_secs
閱讀全文
posted @
2011-03-22 14:45 走走停停又三年 閱讀(2855) |
評(píng)論 (1) |
編輯 收藏
摘要:
閱讀全文
posted @
2010-09-10 11:22 走走停停又三年 閱讀(2221) |
評(píng)論 (5) |
編輯 收藏
摘要: Weblogic92, connection pool, pinned-to-thread, max-capacity
閱讀全文
posted @
2009-12-22 15:52 走走停停又三年 閱讀(2246) |
評(píng)論 (2) |
編輯 收藏
摘要: Weblogic, Apache ,HALF_OPEN_SOCKET_RETRY,“No backend server available”
閱讀全文
posted @
2009-09-14 08:54 走走停停又三年 閱讀(6642) |
評(píng)論 (5) |
編輯 收藏
摘要: JVTM TI, class文件動(dòng)態(tài)更新, 熱部署
閱讀全文
posted @
2009-09-11 00:04 走走停停又三年 閱讀(2779) |
評(píng)論 (5) |
編輯 收藏
摘要: JVM TI、VirtualMachine、dt_socket、Weblogic、stuck thread、terminate
閱讀全文
posted @
2009-09-10 15:18 走走停停又三年 閱讀(5989) |
評(píng)論 (6) |
編輯 收藏
摘要: JDK、MBean、動(dòng)態(tài)打開(kāi)verbose class
閱讀全文
posted @
2009-09-08 09:46 走走停停又三年 閱讀(2926) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblogic10, thread stuck, http, defaultReadTimeout,defaultConnectTimeout
閱讀全文
posted @
2009-08-29 23:15 走走停停又三年 閱讀(3670) |
評(píng)論 (0) |
編輯 收藏
摘要: weblogic92, connection pool, current capacity, initial capacity
閱讀全文
posted @
2009-08-29 23:15 走走停停又三年 閱讀(7129) |
評(píng)論 (3) |
編輯 收藏
摘要: Weblogic, Global Transaction(全局事務(wù)), MultiThread(多線程)
閱讀全文
posted @
2009-07-31 15:18 走走停停又三年 閱讀(2490) |
評(píng)論 (0) |
編輯 收藏
摘要: IBM JDK1.6 SR2 ClassFormatError: JVMCFRE068 類(lèi)名無(wú)效
閱讀全文
posted @
2009-07-27 14:15 走走停停又三年 閱讀(4099) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblgic92, ActiveMQ5.2 集成
閱讀全文
posted @
2009-07-10 15:07 走走停停又三年 閱讀(2135) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblogic, JMS, Message Pending的問(wèn)題
閱讀全文
posted @
2009-06-17 09:07 走走停停又三年 閱讀(3876) |
評(píng)論 (9) |
編輯 收藏
摘要: Weblogic92, JDBC Store引發(fā)的ORA-00001問(wèn)題
閱讀全文
posted @
2009-06-16 09:03 走走停停又三年 閱讀(2334) |
評(píng)論 (3) |
編輯 收藏
摘要: Oracle, Undo, Redo, DataFile
閱讀全文
posted @
2009-06-11 17:50 走走停停又三年 閱讀(1927) |
評(píng)論 (0) |
編輯 收藏
摘要: Oracle, LogMiner, Redo Log, Transaction
閱讀全文
posted @
2009-06-09 13:39 走走停停又三年 閱讀(2052) |
評(píng)論 (0) |
編輯 收藏
摘要: Oracle9i, pfile, spfile, non-dynamic-parameters
閱讀全文
posted @
2009-06-08 15:42 走走停停又三年 閱讀(1678) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblogic, JMS 消息狀態(tài)解析
閱讀全文
posted @
2009-05-21 15:27 走走停停又三年 閱讀(1648) |
評(píng)論 (0) |
編輯 收藏
摘要: Procedure, In/Out parmeters, CallableStatement
閱讀全文
posted @
2009-05-08 13:19 走走停停又三年 閱讀(1313) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblogic, JMS, FileStore, Consumer, MessageListener
閱讀全文
posted @
2009-04-22 09:35 走走停停又三年 閱讀(4187) |
評(píng)論 (3) |
編輯 收藏
摘要: 如何通過(guò)ldap browser監(jiān)控weblogic server的embedded ldap server
閱讀全文
posted @
2009-04-14 15:32 走走停停又三年 閱讀(2405) |
評(píng)論 (0) |
編輯 收藏
摘要: 如果通過(guò)參數(shù)設(shè)定促使PermGen中的ClassUnloading,以避免PermGen的OOM
閱讀全文
posted @
2009-04-14 10:46 走走停停又三年 閱讀(1353) |
評(píng)論 (1) |
編輯 收藏
摘要: Weblogic, internal, transaction timeout, wakeUpAfterSeconds
閱讀全文
posted @
2009-02-24 10:54 走走停停又三年 閱讀(3972) |
評(píng)論 (2) |
編輯 收藏
摘要: Weblogic, RollbackException: SubCoordinator not available, TLog, CoordinatorDescriptor, ServerID
閱讀全文
posted @
2009-02-23 08:07 走走停停又三年 閱讀(3361) |
評(píng)論 (7) |
編輯 收藏
先后有客戶(hù)碰到weblogic92, weblogic10.3在linxu上啟動(dòng)慢的問(wèn)題。從thread dump來(lái)看,線程掛在security相關(guān)的隨機(jī)數(shù)生成上面,因?yàn)榭蛻?hù)沒(méi)有把thread dump發(fā)過(guò)來(lái),所以這里就沒(méi)得貼了。
解決方法:
-Djava.security.egd=file:/dev/urandom(可能還會(huì)有問(wèn)題)
-Djava.security.egd=file:/dev/zero(可以解決問(wèn)題)
posted @
2009-01-22 14:27 走走停停又三年 閱讀(1378) |
評(píng)論 (0) |
編輯 收藏
摘要: weblogic, XAER_NOTA, enlist
閱讀全文
posted @
2009-01-12 20:48 走走停停又三年 閱讀(3219) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblogic中的load banlance問(wèn)題
閱讀全文
posted @
2009-01-12 20:08 走走停停又三年 閱讀(4092) |
評(píng)論 (0) |
編輯 收藏
摘要: HttpCompleteMessageTimeout, BEA-101083, BEA-101326
閱讀全文
posted @
2008-12-12 09:55 走走停停又三年 閱讀(5355) |
評(píng)論 (2) |
編輯 收藏
摘要: Weblogic中的asynchronous web service調(diào)用,關(guān)鍵詞: web service, asynchronous , FutureResult, AsyncInfo, setResultListener
閱讀全文
posted @
2008-11-24 22:38 走走停停又三年 閱讀(2791) |
評(píng)論 (1) |
編輯 收藏
摘要: Weblogic執(zhí)行transaction recover碰到的奇怪問(wèn)題
閱讀全文
posted @
2008-11-23 19:55 走走停停又三年 閱讀(2332) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblogic中幾個(gè)可以通過(guò)反射配置屬性的MBean
閱讀全文
posted @
2008-11-20 18:17 走走停停又三年 閱讀(1658) |
評(píng)論 (0) |
編輯 收藏
摘要: 解析DynamicServerList在Weblogic plugin(HttpClusterServlet)中的實(shí)現(xiàn)
閱讀全文
posted @
2008-11-13 13:48 走走停停又三年 閱讀(2617) |
評(píng)論 (6) |
編輯 收藏
摘要: 本文主要討論通過(guò)JDBC調(diào)用SQL Server存儲(chǔ)過(guò)程碰到的"java.sql.SQLException: [BEA][SQLServer JDBC Driver][SQLServer]The server failed to resume the transaction. Desc:******* 問(wèn)題
閱讀全文
posted @
2008-10-28 19:38 走走停停又三年 閱讀(9074) |
評(píng)論 (0) |
編輯 收藏
摘要: weblogic-ejb-jar.xml的元素解析
閱讀全文
posted @
2008-10-10 23:42 走走停停又三年 閱讀(3995) |
評(píng)論 (0) |
編輯 收藏
摘要: Weblogic, Session, Persistence, JDBC, 性能問(wèn)題
閱讀全文
posted @
2008-09-27 17:18 走走停停又三年 閱讀(3662) |
評(píng)論 (2) |
編輯 收藏
摘要: Weblogic, log rotation, i node number, Tivoli
閱讀全文
posted @
2008-09-27 14:05 走走停停又三年 閱讀(2183) |
評(píng)論 (0) |
編輯 收藏
摘要: Java, static, 遞歸, Class.forName(), Classloader
閱讀全文
posted @
2008-09-26 12:38 走走停停又三年 閱讀(2360) |
評(píng)論 (3) |
編輯 收藏
摘要: ClassNotFoundException,NoClassDefFoundError,區(qū)別
閱讀全文
posted @
2008-09-25 19:45 走走停停又三年 閱讀(9670) |
評(píng)論 (5) |
編輯 收藏