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

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

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

    Dev Zone
    偏執狂才能生存,人生/事業的路上需要再堅持一下
    但是又怎么說得清堅持的結果,道得盡堅持的含義
    1. sleepTime:PoolKeeper檢測時間間隔
    2. lifeTime:連接生命周期(上次訪問時間-當前時間)
    3. deadLockMaxWait(:超過最大連接之后的調用getConnection的等待時間
    4. deadLockRetryWait:超過最大連接之后的調用getConnection等待,在等待中重試的時間間隔
    5. maxSize:連接池的容量

    deald-lock-max-wait和dead-lock-retry-wait的設置要小心,這兩個參數的意義見我的另一個日志:XAPool原理簡要分析。dead-lock-retry-wait最好設置得比較短,這樣不至于線程等待很長時間,dead-lock-max-wait的設置不要太長,一般是設置成比最高并發數下應用處理時間稍長一點,設置過短在大并發下會造成提交實效導致應用數據的丟失,因為超過xapool在超過等待dead-lock-max-wait之后會異常:沒有可用連接分配。

     

    sleepTime是對Connection idle檢測線程PoolKeeper的檢測時間間隔設置。PoolKeeper會定時監測是否存在超過lifeTime的connection然后釋放掉這些connection。不過PoolKeeper在運行的時候會檢查running屬性,以下是它的run方法中的代碼片斷:

      while (! running && !Thread.interrupted()) {
          System.err.println(
    "!!!!"+System.currentTimeMillis());
       
    try {
        synchronized (
    this) {
         wait(
    this.sleepTime); // wait for timeout ms before attack
        }
       } 
    catch (InterruptedException e) {
                                    
    break;
       }
       
    this.pool.cleanUp(); // clean up the Pool and reallocate objects
      }
      
    // release the pool.
      this.pool = null;

    之所以把這段代碼粘出來,是因為running屬性默認是true,而GenericPool在啟動PookKeeper的時候并沒有改變這個值,因此PookKeeper永遠不會運行起來。也許這是xapool的另一個bug:)

    連接池的容量設置是有講究的,一般至少等于AppServer(或者叫WEB 容器)的最大并發數。因為xapool在達到maxSize的時候,如果還有線程需要連接,會進入等待狀態(通過deadLockMaxWait設置最大等待時間,deadLockRetryWait設置等待間隔),在大并發下會造成App Server容器線程池滿,Server在一段時間內(deadLockMaxWait)停止響應的現象。將連接池的容量設置成大于App Server的最大并發數,可以盡可能的避免這種情況。App Server的最大并發數=App Server的線程池線程數,Tomcat默認是75,Websphere默認是50。集群環境下,集群的最大并發數=每臺集群服務器的最大并發數之和

    posted on 2005-05-17 22:06 dev 閱讀(2402) 評論(1)  編輯  收藏
    Comments
    • # re: XAPool的參數設置
      路人甲
      Posted @ 2008-11-04 09:22
      XA1.5的這段代碼已修改了:

      public void run() {
      while (running && !Thread.interrupted()) {
      try {
      synchronized (this) {
      wait(this.sleepTime); // wait for timeout ms before attack
      }
      } catch (InterruptedException e) {
      break;
      }
      this.pool.cleanUp(); // clean up the Pool and reallocate objects
      }
      // release the pool.
      this.pool = null;
      }  回復  更多評論   

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
     
    主站蜘蛛池模板: 免费在线观看h片| 国产精品偷伦视频观看免费| 69式国产真人免费视频| 亚洲AV日韩AV鸥美在线观看| 国产午夜无码片免费| 亚洲自偷自偷在线制服| 在线免费播放一级毛片| 亚洲精品福利视频| 最近在线2018视频免费观看| 亚洲字幕在线观看| 免费不卡视频一卡二卡| 亚洲成a人无码亚洲成www牛牛 | 免费无码一区二区三区| 亚洲综合久久综合激情久久| 91高清免费国产自产| 亚洲а∨天堂久久精品9966| 日本高清免费不卡在线| 一个人看的www视频免费在线观看 一个人看的免费观看日本视频www | 久久青青草原国产精品免费| 亚洲AV无码国产精品麻豆天美| 99在线免费观看视频| 亚洲欧洲自拍拍偷综合| 精品熟女少妇AV免费观看| 美女黄网站人色视频免费| 国产精品亚洲综合一区| 69式互添免费视频| 亚洲爆乳无码精品AAA片蜜桃| 亚洲福利精品电影在线观看| 免费无码一区二区三区蜜桃| 亚洲人成日本在线观看| 免费看小12萝裸体视频国产| a在线免费观看视频| 亚洲黄色激情视频| 国产亚洲欧洲Aⅴ综合一区| 2020因为爱你带字幕免费观看全集| 亚洲精品二三区伊人久久| 亚洲国产电影av在线网址| 99久久久精品免费观看国产| 特级毛片A级毛片免费播放| 亚洲午夜免费视频| 亚洲国产精品尤物yw在线|