itstarting:IT進行時

          想自己所想,做自己所愛

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            28 隨筆 :: 3 文章 :: 55 評論 :: 0 Trackbacks

          解決連接池泄漏步驟

          登錄weblogic console,  %Domain% -> Services -> JDBC -> Connection Pools -> jdbc/ioa

           

          Configuration -> Connection, 點開Advanced Options, 修改以下配置項狀態:

           

          配置項名稱

          默認值

          修改為

          說明

          Enable Connection Leak Profiling

          禁用

          啟用

          開啟連接池泄漏的監控。

          Enable Connection Profiling

          禁用

          啟用

          開啟連接池監控。

          Inactive Connection Timeout

          0

          100

          連接在指定時間內(單位:秒)沒有活動的話,WebLogic會將之釋放并回收到連接池。

           

              以上配置項修改后不影響在跑的應用,不需要重啟服務器或應用(配置項前沒有黃色小圖標 <!--[if !vml]--><!--[endif]-->WebLogic很明確的告訴我們這個配置是不需要重啟的),所以大可放心設置。只是啟用監控后會對性能有一些影響,具體影響會有多大,我沒有測試過,但開啟這些設置只是暫時的,得到日志后我們就可以把配置還原會默認值。

          在沒有解決連接池泄漏問題之前,如果沒有請求時連接池將一直保持為0,不會再有連接池滿造成請求無法響應的問題,我們也不用擔心再挨客戶罵,也為我們解決問題爭取了寶貴到時間。

           

                 好了,下面才是關鍵。

           

                 過一段時間后,在bea\user_projects\domains\%domainname%\%servername%目錄下,打開%servername%.log,查找,"A JDBC pool connection leak was detected",如果WebLogic已經監控到有連接池泄漏的話,就可以找到以下日志,并且很清楚的告訴我們在哪一個類的哪行代碼創建了連接,但沒有關閉(注意紅色加粗字體):


           

          2008-5-22 上午114720 CST       Warning     JDBC                A JDBC pool connection leak was detected. A connection leak occurs when a connection obtained from the pool was not closed explicitly by calling close() and then was disposed by the garbage collector and returned to the connection pool. The following stack trace at create shows where the leaked connection was created. Stack trace at connection create:

                 at weblogic.jdbc.wrapper.PoolConnection.init(PoolConnection.java:75)

                 at weblogic.jdbc.pool.Driver.allocateConnection(Driver.java:254)

                 at weblogic.jdbc.pool.Driver.connect(Driver.java:84)

                 at weblogic.jdbc.jts.Driver.getNonTxConnection(Driver.java:546)

                 at weblogic.jdbc.jts.Driver.connect(Driver.java:140)

                 at weblogic.jdbc.common.internal.RmiDataSource.getConnection(RmiDataSource.java:344)

                 at com.cp.fw.dao.BaseDAO.getConnection(BaseDAO.java:78)

                 at com.cp.fw.dao.dataset.DataSetOp.init(DataSetOp.java:78)

                 at com.cp.fw.dao.dataset.DataSetOp.<init>(DataSetOp.java:45)

                 at com.cp.ia.util.WorkFlowUtil.getNextWrokFlowId(WorkFlowUtil.java:93)

                 at

           

          ……

                

           

                 另外一種方法:

          WebLogic Console,展開 %DomainName% -> Servers -> %ServerName%,選到Logging – Server頁,在頁面最下方點擊 "View server log",同樣查找 "A JDBC pool connection leak was detected",也可以找到同樣的日志。

           

          WebLogic對于日志事件的說明:

           

          Message ID

          BEA-001074

          Subsystem

          JDBC

          Message

          A JDBC pool connection leak was detected. A

          connection leak occurs when a connection obtained

          from the pool was not closed explicitly by calling

          close() and then was disposed by the garbage

          collector and returned to the connection pool. The

          following stack trace at create shows where the

          leaked connection was created.  Stack trace at

          connection create:

          Detail

          A JDBC pool connection leak was detected. A

          connection leak occurs when a connection obtained

          from the pool was not closed explicitly by calling

          close() and then was disposed by the garbage

          collector and returned to the connection pool. A

          stack trace is printed indicating where the leaked

          connection was created.

          Cause

          A JDBC pool connection leak was detected. A

          connection leak occurs when a connection obtained

          from the pool was not closed explicitly by calling

          close() and then was disposed by the garbage

          collector and returned to the connection pool. A

          stack trace is printed indicating where the leaked

          connection was created.

          Action

          Close the connection appropriately.



          原文:http://blog.csdn.net/esky2000/archive/2008/07/22/2689929.aspx
          posted on 2008-11-13 00:41 IT進行時 閱讀(1956) 評論(0)  編輯  收藏 所屬分類: Java Tips
          主站蜘蛛池模板: 武川县| 武义县| 彭州市| 涿鹿县| 蕉岭县| 平谷区| 南投县| 民乐县| 夏河县| 富蕴县| 桑日县| 上林县| 苍山县| 武安市| 岐山县| 辽宁省| 南雄市| 句容市| 弥渡县| 陵川县| 竹溪县| 酉阳| 乌拉特后旗| 察哈| 丹阳市| 武功县| 临泉县| 东至县| 信阳市| 马山县| 泸定县| 梁平县| 平塘县| 桂平市| 凉城县| 高陵县| 博罗县| 东阳市| 温宿县| 始兴县| 淮安市|