<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 42,comments - 83,trackbacks - 0
          首先介紹一個JDBC參數InactiveConnectionTImeout,該參數用于強制回收那些被泄露的連接(長時間不使用的連接、未被程序正確釋放的連接),避免連接池因為泄露導致無連接可用。當然該參數只是起輔助作用,解決問題知道還是在于完善應用程序。

          本文和該參數有關,早期的8.1\9.2中,設定該參數時,定時器(內部的連接池維護Task)只會清理那些長期未被使用的空閑連接(從名字上可以看出來),即對于運行一個長時間執行SQL的連接而言,它是不受影響的。但不知道從10.3哪個版本開始(我測試的是10.3.5),該參數對于長時間執行SQL的連接也進行強制回收了(這個比較不合理,雖然對于正在執行的Tx影響不大)。Debug了一下,發現SQL執行時間大于4*InactiveConnectionTimeout時,這個SQL執行完成時,會出現 <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這樣的錯誤。

    //該線程為內部Task執行線程,該線程目前處于被阻塞狀態,等待SQL執行結束后回收連接
    "[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)

    //該線程為應用執行線程,目前該線程SQL正在運行,他阻塞(阻塞對象為T4CConnection)了內部Task執行線程
    "[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)

            從上面的線程堆棧可以看到,內部Task線程正在調用connection的rollback,即回滾連接上的本地事務。如果應用線程上使用的連接設為auto commit的話,該SQL執行不會被rollback,否則該SQL雖然執行完成也會被rollback調(全局事務中,某個事務分支使用的連接一定是非auto commit的),所以該問題對涉及全局事務的應用影響比較大。

            下面我們在看看連接被回收的時間點為什么會出現在3-4個InactiveConnectionTimeout之間。當內部Task執行,發現到了InactiveConnectionTimeout時間點后,它會調用timeoutInactiveResources()方法開始進行連接清理。那么為什么正在執行SQL的連接會被標志為非活動連接呢?這里涉及連接狀態的三個標志位,分別為:conn_in_use,connUsed,hang_state,這三個標志位是其中的關鍵(getUsed()和setUsed()方法中會進行標志位操作及讀取,如果對于某個連接getUsed()返回false的話,該連接會被清理)。下面我們看看其中標志位的變化過程: SQL開始執行時,preInvokeHandler會被這三個標志位進行設定。

    初始值如下:
    conn_in_use-->true
    hang_state-->conn_state_in_use
    connUsed-->true

    第一次InactiveConnectionTimeout檢查,getUsed返回true,同時調用setUsed(false),標志位變化如下:
    conn_in_use-->true
    hang_state-->conn_state_idle_suspect
    connUsed-->true

    第二次InactiveConnectionTimeout檢查,getUsed返回true,同時調用setUsed(false),標志位變化如下:
    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)
    同時調用setUsed(false),標志位變化如下:
    conn_in_use-->false
    connUsed-->false
    hang_state-->conn_state_idle_suspect(從conn_state_in_use變成conn_state_idle_suspect)

    第四次InactiveConnectionTimeout檢查,getUsed返回false,開始回收該連接。

    從上面的變化時間點可以看到從第一次到第四次檢查經歷了完整的3個InactiveConnectionTimout周期,而從SQL執行到第一次檢查點,這個時間小于一個InactiveConnectionTimeout,所以連接開始被回收的時間點介于3-4個InactiveConnectionTimeout之間。




    posted @ 2013-10-10 16:18 走走停停又三年 閱讀(7662) | 評論 (1)編輯 收藏
         摘要: Weblogic10.3.0, connection pool, disable, Weblogic10.3.4, weblogic.resourcepool.max_test_wait_secs  閱讀全文
    posted @ 2011-03-22 14:45 走走停停又三年 閱讀(2855) | 評論 (1)編輯 收藏
         摘要:   閱讀全文
    posted @ 2010-09-10 11:22 走走停停又三年 閱讀(2221) | 評論 (5)編輯 收藏
         摘要: Weblogic92, connection pool, pinned-to-thread, max-capacity  閱讀全文
    posted @ 2009-12-22 15:52 走走停停又三年 閱讀(2246) | 評論 (2)編輯 收藏
         摘要: Weblogic, Apache ,HALF_OPEN_SOCKET_RETRY,“No backend server available”  閱讀全文
    posted @ 2009-09-14 08:54 走走停停又三年 閱讀(6642) | 評論 (5)編輯 收藏
         摘要: JVTM TI, class文件動態更新, 熱部署  閱讀全文
    posted @ 2009-09-11 00:04 走走停停又三年 閱讀(2779) | 評論 (5)編輯 收藏
         摘要: JVM TI、VirtualMachine、dt_socket、Weblogic、stuck thread、terminate  閱讀全文
    posted @ 2009-09-10 15:18 走走停停又三年 閱讀(5989) | 評論 (6)編輯 收藏
         摘要: JDK、MBean、動態打開verbose class  閱讀全文
    posted @ 2009-09-08 09:46 走走停停又三年 閱讀(2926) | 評論 (0)編輯 收藏
         摘要: Weblogic10, thread stuck, http, defaultReadTimeout,defaultConnectTimeout  閱讀全文
    posted @ 2009-08-29 23:15 走走停停又三年 閱讀(3670) | 評論 (0)編輯 收藏
         摘要: weblogic92, connection pool, current capacity, initial capacity  閱讀全文
    posted @ 2009-08-29 23:15 走走停停又三年 閱讀(7129) | 評論 (3)編輯 收藏
         摘要: Weblogic, Global Transaction(全局事務), MultiThread(多線程)  閱讀全文
    posted @ 2009-07-31 15:18 走走停停又三年 閱讀(2490) | 評論 (0)編輯 收藏
         摘要: IBM JDK1.6 SR2 ClassFormatError: JVMCFRE068 類名無效  閱讀全文
    posted @ 2009-07-27 14:15 走走停停又三年 閱讀(4099) | 評論 (0)編輯 收藏
         摘要: Weblgic92, ActiveMQ5.2 集成  閱讀全文
    posted @ 2009-07-10 15:07 走走停停又三年 閱讀(2135) | 評論 (0)編輯 收藏
         摘要: Weblogic, JMS, Message Pending的問題  閱讀全文
    posted @ 2009-06-17 09:07 走走停停又三年 閱讀(3876) | 評論 (9)編輯 收藏
         摘要: Weblogic92, JDBC Store引發的ORA-00001問題  閱讀全文
    posted @ 2009-06-16 09:03 走走停停又三年 閱讀(2334) | 評論 (3)編輯 收藏
         摘要: Oracle, Undo, Redo, DataFile  閱讀全文
    posted @ 2009-06-11 17:50 走走停停又三年 閱讀(1927) | 評論 (0)編輯 收藏
         摘要: Oracle, LogMiner, Redo Log, Transaction  閱讀全文
    posted @ 2009-06-09 13:39 走走停停又三年 閱讀(2052) | 評論 (0)編輯 收藏
         摘要: Oracle9i, pfile, spfile, non-dynamic-parameters  閱讀全文
    posted @ 2009-06-08 15:42 走走停停又三年 閱讀(1678) | 評論 (0)編輯 收藏
         摘要: Weblogic, JMS 消息狀態解析  閱讀全文
    posted @ 2009-05-21 15:27 走走停停又三年 閱讀(1648) | 評論 (0)編輯 收藏
         摘要: Procedure, In/Out parmeters, CallableStatement  閱讀全文
    posted @ 2009-05-08 13:19 走走停停又三年 閱讀(1313) | 評論 (0)編輯 收藏
         摘要: Weblogic, JMS, FileStore, Consumer, MessageListener  閱讀全文
    posted @ 2009-04-22 09:35 走走停停又三年 閱讀(4187) | 評論 (3)編輯 收藏
         摘要: 如何通過ldap browser監控weblogic server的embedded ldap server  閱讀全文
    posted @ 2009-04-14 15:32 走走停停又三年 閱讀(2405) | 評論 (0)編輯 收藏
         摘要: 如果通過參數設定促使PermGen中的ClassUnloading,以避免PermGen的OOM  閱讀全文
    posted @ 2009-04-14 10:46 走走停停又三年 閱讀(1353) | 評論 (1)編輯 收藏
         摘要: Weblogic, internal, transaction timeout, wakeUpAfterSeconds  閱讀全文
    posted @ 2009-02-24 10:54 走走停停又三年 閱讀(3972) | 評論 (2)編輯 收藏
         摘要: Weblogic, RollbackException: SubCoordinator not available, TLog, CoordinatorDescriptor, ServerID  閱讀全文
    posted @ 2009-02-23 08:07 走走停停又三年 閱讀(3361) | 評論 (7)編輯 收藏

            先后有客戶碰到weblogic92, weblogic10.3在linxu上啟動慢的問題。從thread dump來看,線程掛在security相關的隨機數生成上面,因為客戶沒有把thread dump發過來,所以這里就沒得貼了。
    解決方法:
    -Djava.security.egd=file:/dev/urandom(可能還會有問題)
    -Djava.security.egd=file:/dev/zero(可以解決問題)

    posted @ 2009-01-22 14:27 走走停停又三年 閱讀(1378) | 評論 (0)編輯 收藏
         摘要: weblogic, XAER_NOTA, enlist  閱讀全文
    posted @ 2009-01-12 20:48 走走停停又三年 閱讀(3219) | 評論 (0)編輯 收藏
         摘要: Weblogic中的load banlance問題   閱讀全文
    posted @ 2009-01-12 20:08 走走停停又三年 閱讀(4092) | 評論 (0)編輯 收藏
         摘要: HttpCompleteMessageTimeout, BEA-101083, BEA-101326  閱讀全文
    posted @ 2008-12-12 09:55 走走停停又三年 閱讀(5355) | 評論 (2)編輯 收藏
         摘要: Weblogic中的asynchronous web service調用,關鍵詞: web service, asynchronous , FutureResult, AsyncInfo, setResultListener  閱讀全文
    posted @ 2008-11-24 22:38 走走停停又三年 閱讀(2791) | 評論 (1)編輯 收藏
         摘要: Weblogic執行transaction recover碰到的奇怪問題  閱讀全文
    posted @ 2008-11-23 19:55 走走停停又三年 閱讀(2332) | 評論 (0)編輯 收藏
         摘要: Weblogic中幾個可以通過反射配置屬性的MBean  閱讀全文
    posted @ 2008-11-20 18:17 走走停停又三年 閱讀(1658) | 評論 (0)編輯 收藏
         摘要: 解析DynamicServerList在Weblogic plugin(HttpClusterServlet)中的實現  閱讀全文
    posted @ 2008-11-13 13:48 走走停停又三年 閱讀(2617) | 評論 (6)編輯 收藏
         摘要: 本文主要討論通過JDBC調用SQL Server存儲過程碰到的"java.sql.SQLException: [BEA][SQLServer JDBC Driver][SQLServer]The server failed to resume the transaction. Desc:******* 問題  閱讀全文
    posted @ 2008-10-28 19:38 走走停停又三年 閱讀(9074) | 評論 (0)編輯 收藏
         摘要: weblogic-ejb-jar.xml的元素解析   閱讀全文
    posted @ 2008-10-10 23:42 走走停停又三年 閱讀(3995) | 評論 (0)編輯 收藏
         摘要: Weblogic, Session, Persistence, JDBC, 性能問題  閱讀全文
    posted @ 2008-09-27 17:18 走走停停又三年 閱讀(3662) | 評論 (2)編輯 收藏
         摘要: Weblogic, log rotation, i node number, Tivoli  閱讀全文
    posted @ 2008-09-27 14:05 走走停停又三年 閱讀(2183) | 評論 (0)編輯 收藏
         摘要: Java, static, 遞歸, Class.forName(), Classloader  閱讀全文
    posted @ 2008-09-26 12:38 走走停停又三年 閱讀(2360) | 評論 (3)編輯 收藏
         摘要: ClassNotFoundException,NoClassDefFoundError,區別   閱讀全文
    posted @ 2008-09-25 19:45 走走停停又三年 閱讀(9670) | 評論 (5)編輯 收藏
         摘要: Weblogic, Dom4j, SAXParserFactpry,ZipFile.getEntry(), class loader. 本文闡述了weblogic中使用dom4j時,如何定義SAXParserFactory實現類的問題。  閱讀全文
    posted @ 2008-09-13 21:57 走走停停又三年 閱讀(2961) | 評論 (1)編輯 收藏
         摘要: Weblogic, WLConnection, getVendorConnection, PreparedStatement cache, DDL, 本文闡述了在weblogic中使用了prepared statement cache的情況下,如果后臺數據庫因為DDL而導致表結構發生變化的時候,如何規避prepared statement導致的SQLException。  閱讀全文
    posted @ 2008-09-12 12:26 走走停停又三年 閱讀(2087) | 評論 (1)編輯 收藏
    主站蜘蛛池模板: 国产福利电影一区二区三区,亚洲国模精品一区 | 一级**爱片免费视频| 国产女高清在线看免费观看 | 亚洲校园春色小说| 国产亚洲免费的视频看 | 亚洲国产精品成人精品软件| 最近2022中文字幕免费视频| 亚洲精品国产专区91在线| 亚洲日本在线免费观看| 亚洲乱码一区av春药高潮| 在线A级毛片无码免费真人| 亚洲精品精华液一区二区| 日本免费电影一区| 免费大片av手机看片| 国产亚洲人成A在线V网站| 伊人久久大香线蕉免费视频| 亚洲AV无码专区在线播放中文| 18禁成人网站免费观看| 国产精品亚洲自在线播放页码| 免费看的黄色大片| 一级成人毛片免费观看| 亚洲AV日韩AV永久无码下载| 欧亚精品一区三区免费| 香蕉97碰碰视频免费| 亚洲一区爱区精品无码| 日本高清在线免费| 男女猛烈xx00免费视频试看| 亚洲AV永久青草无码精品| 男男AV纯肉无码免费播放无码 | 美女扒开屁股让男人桶爽免费| 奇米影视亚洲春色| 亚欧免费视频一区二区三区| 国产精品成人亚洲| 亚洲国产日韩一区高清在线| 在线观看免费污视频| 天黑黑影院在线观看视频高清免费 | 亚洲欧洲国产成人精品| 亚洲人成色7777在线观看不卡| 久久国产免费观看精品3| 最新亚洲人成网站在线观看 | 亚洲色精品88色婷婷七月丁香|