国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 課堂 > 基礎知識 > 正文

Mycat 連接池模型源碼

2024-09-12 20:30:04
字體:
來源:轉載
供稿:網(wǎng)友

  PhysicalDBNode 是Mycat集群(Datanode)的對應,引用一個連接池對象 PhysicalDBPool,
  PhysicalDBPool 里面引用了真正的連接池對象 PhysicalDatasource,PhysicalDBPool 里面把該
  集群的讀節(jié)點,寫節(jié)點寫入各自的 PhysicalDatasource 數(shù)組,通過負載均衡決定走哪個節(jié)點
  負載均衡策略:隨機選擇,按權重設置隨機概率
  代碼:randomSelect
  節(jié)點權重計算公式String weightStr = node.getAttribute("weight");
  int weight = "".equals(weightStr) ? PhysicalDBPool.WEIGHT : Integer.parseInt(weightStr) ;
  負載均衡:offset -= okSources.get(i).getConfig().getWeight();
  沒明白為什么這么分配,難道可用達到權重越大,分配可能性越小???
 
  public PhysicalDatasource randomSelect(ArrayList<PhysicalDatasource> okSources) {
 
     if (okSources.isEmpty()) {
        return this.getSource();
 
     } else {      
 
        int length = okSources.size();     // 總個數(shù)
          int totalWeight = 0;         // 總權重
          boolean sameWeight = true;        // 權重是否都一樣
          for (int i = 0; i < length; i++) {            
              int weight = okSources.get(i).getConfig().getWeight();
              totalWeight += weight;        // 累計總權重               
              if (sameWeight && i > 0
                    && weight != okSources.get(i-1).getConfig().getWeight() ) {      // 計算所有權重是否一樣                              
                  sameWeight = false;    
              }
          }
 
          if (totalWeight > 0 && !sameWeight ) {
 
             // 如果權重不相同且權重大于0則按總權重數(shù)隨機
              int offset = random.nextInt(totalWeight);
 
              // 并確定隨機值落在哪個片斷上
              for (int i = 0; i < length; i++) {
                  offset -= okSources.get(i).getConfig().getWeight();
                  if (offset < 0) {
                      return okSources.get(i);
                  }
              }
          }
 
          // 如果權重相同或權重為0則均等隨機
          return okSources.get( random.nextInt(length) );    
 
        //int index = Math.abs(random.nextInt()) % okSources.size();
        //return okSources.get(index);
     }
  }
  PhysicalDatasource 連接池對象保存該連接的可用連接使用的數(shù)據(jù)結構是,ConMap,主要功能是獲取當前節(jié)點的可用連接,首先從當前database上獲取可用連接,如果沒有,則從其他 database 上獲取可用連接
 
  public BackendConnection tryTakeCon(final String schema, boolean autoCommit) {
     final ConQueue queue = items.get(schema);
     BackendConnection con = tryTakeCon(queue, autoCommit);
     if (con != null) {
        return con;
     } else {
        for (ConQueue queue2 : items.values()) {
           if (queue != queue2) {
              con = tryTakeCon(queue2, autoCommit);
              if (con != null) {
                 return con;
              }
           }
        }
     }
     return null;
 
  }
  private BackendConnection tryTakeCon(ConQueue queue, boolean autoCommit) {
 
     BackendConnection con = null;
     if (queue != null && ((con = queue.takeIdleCon(autoCommit)) != null)) {
        return con;
     } else {
        return null;
     }
 
  }
  database的可用連接是存放在數(shù)據(jù)結構ConQueue中的,可用連接分為自動提交,手動提交,所以ConQueue由2個ConcurrentLinkedQueue組成,autoCommitCons 自動提交隊列,manCommitCons 手動提交隊列
  分配可用連接:先從提交方式隊列隊首分配,分配失敗,從另一個隊列分配,分配失敗,從其他databse 分配。猜想:此處分配完成應該不是最種的可用連接,還需要做事務隔離級別、事務模式、字符集、Database 等等處理和校驗,才能執(zhí)行具體的 sql 指令,這些應該是在MySQLConnection 類中進行的
 
  public BackendConnection takeIdleCon(boolean autoCommit) {
     ConcurrentLinkedQueue<BackendConnection> f1 = autoCommitCons;
     ConcurrentLinkedQueue<BackendConnection> f2 = manCommitCons;
 
     if (!autoCommit) {
        f1 = manCommitCons;
        f2 = autoCommitCons;
 
     }
     BackendConnection con = f1.poll();
     if (con == null || con.isClosedOrQuit()) {
        con = f2.poll();
     }
     if (con == null || con.isClosedOrQuit()) {
        return null;
     } else {
        return con;
     }

(編輯:武林網(wǎng))

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
亚洲精品一线| 免费影视观看网站入口| 免费久久网站| 白浆爆出在线观看| 超碰国产在线| 综合激情亚洲| 国产9色视频| av日韩国产| 91欧美在线视频| 亚洲欧美日韩一区成人| 激情网站在线| 96久久久久久| 成年人在线观看| 国产精品被窝福利一区| 思思99精品视频在线观看| 国产精品午夜久久久久久| 97在线超碰| 五月天亚洲激情| 亚洲精品国自产拍在线观看| 国产在线超碰| xxxxx中文字幕| 国产欧美日韩专区| 免费在线看v| 国产国产人免费人成免费视频| 日本在线观看网站| 国产超级va在线视频| 激情视频国产| 啪啪免费视频一区| 精品国语对白精品自拍视| 国产精品亚洲第五区在线| 久久五月精品| 在线观看免费黄色| 国产精品久久精品牛牛影视| 国产毛片毛片| 国产秒拍福利视频露脸| 久精品在线观看| 日本卡一卡2卡3卡4精品卡网站| 国产三级在线免费| www久久日com| 九色在线网站| 久久精品国产亚洲a∨麻豆| jizz在线免费观看| 人人在线视频| 青青青国产视频| а√最新版在线天堂| 在线观看av的网站| 色悠久久久久综合网小说| av手机免费观看| 国产福利热线视频| 亚洲第一区视频| www在线视频| 国产九九九九| 尤物在线网址| 国产偷窥老熟盗摄视频| 国产激情在线视频| 亚洲日本伊人| 国产免费av高清在线| 国产一卡2卡3卡4卡网站免费| 成人无遮挡免费网站视频在线观看| 国产麻豆精品一区二区三区v视界| 国产一卡2卡3卡4卡网站免费| 国产一二三区在线| 国产福利三区| 青青草中文字幕| 国自产拍在线网站网址视频| 国产精品㊣新片速递bt| 国产福利图片| 九九热免费视频| 高潮白浆视频| 国产一二三区在线| 四虎免费视频| 国产美女福利在线| 亚洲天堂电影在线观看| 成人亚洲一区二区三区| 亚洲人在线播放| 国产三级在线播放| 国产美女一区视频| 日韩国产成人| 中文视频在线| 国产精品久久久高清免费| 热99在线观看| 国产福利在线| 国产免费视频在线| 在线国产中文字幕| 国产区视频在线观看| 国内精品一区视频| 日本aⅴ写真网站免费| 国产91足控脚交在线观看| 天堂在线中文| 久草视频国产| 欧美96在线| 亚洲天堂久久久| 在线观看免费高清完整| 国产91在线视频蝌蚪| 丁香在线视频| 91sp网站在线观看入口| 免费网站看黄yyy222| 亚洲精品aaaa精品| 国产桃色电影在线播放| 黄色国产网站在线播放| 日韩不卡高清| 欧美高清xxxx性| 白浆爆出在线观看| 开心丁香婷婷深爱五月| 日本免费视频www| 日韩不卡高清| www狠狠操| 福利视频网址导航| 国产一级在线观看| 国产精品69xx| 69精品视频| 精品国产二区三区| 亚洲精品aaaa精品| 日本不卡视频一区二区| 美女被人操视频在线观看| а√最新版在线天堂| 久久91精品视频| 中文字幕欧美日韩在线不卡| 国产女王在线**视频| 永久免费网站在线| xxxxx中文字幕| 最近中文av字幕在线中文| 91免费日韩| 精品中文字幕不卡在线视频| 成人超碰在线| 国产精品久久人| 中文在线视频| 日本成人网址| 国产在线更新| 在线中文字幕视频| 国产农村av| 午夜小视频在线| 国产精品视频一区二区免费不卡 | 久久久久久久久久久久久91| 午夜不卡视频| av中文字幕在线看| 中文字幕在线免费看| 中文在线官网天堂| 国精一区二区三区| 亚洲天堂久久久| 国产精品被窝福利一区| 九色精品视频在线观看| 精品国产高清a毛片无毒不卡 | 欧美日韩在线中文字幕| 1区不卡电影| 麻豆网站在线| gogo高清在线播放免费| 成人欧美日韩| 男人操女人免费网站| 日韩黄色成人| av在线日韩国产精品| 尤物视频在线观看视频| 在线国产福利网站| 在线国产1区| 在线一区观看| 一区免费观看| 亚洲wwwwww| 青青免费在线视频| 日本免费视频www| 在线观看av资源网| baoyu777.永久免费视频| 亚洲精品aaaa精品| 91av福利| 亚洲精品影院在线| av在线播放网| 狠狠色综合久久婷婷| 国产男女猛烈无遮挡免费视频| 激情丁香在线| 国产网红在线观看| 91美女在线| 日本视频三区| av中文网站| www在线视频观看| 狂野欧美性猛交xxxx乱大交| 日本福利在线| 天天爱天天色| 97一区二区三区| 精品a在线观看| 香蕉视频免费在线播放| 国产在线免费观看| 国产精品久久在线| www.毛片| 国产叼嘿网站免费观看不用充会员| 国产高清视频在线| baoyu777.永久免费视频| 91超碰国产在线| 99热国产在线| 麻豆精品不卡国产免费看| 五月综合激情在线| 在线视频三级| 九七电影韩国女主播在线观看| 久久av少妇| 2019年中文字幕| 欧美视频免费一区二区三区| 中文字幕在线看精品乱码| 精品伦理一区二区| 国产麻豆视频网站| 香蕉视频免费在线播放| 国产福利视频在线| 综合图区亚洲白拍在线|