亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

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

MHA源代碼之主庫采取

2024-09-12 20:29:54
字體:
來源:轉載
供稿:網友
        MHA源代碼之主庫選取:

一 、MHA 選舉主庫所維護的數組
      在講MHA選擇 master的代碼中,我們必須把維護的四個數組的來龍去脈講清楚
 
(1) Alive_slaves 數組 :
       server不是 master,且從庫正常, latest數組中的 server有足夠的中繼日志恢復這個落后的從庫 (追上主庫 ),則放入這個 Alive_slaves的數組中 (此段代碼在 ServerManager.pm: init_servers函數 )
 
 
    if ( $server->{dead} ) {
      $self->add_dead_server($server);
    }
    elsif ( $server->{unmanaged} ) {
      $self->add_unmanaged_slave($server);
    }
    #不是dead或者unmanaged就加入alive_server數組,如果show slave status 不是返回0E0,且這個server不是原來的主庫,并且sql線程無誤且可以用中繼日志來恢復,就加入alive_slave數據,否則加入failed——slave數組
    else {
      $self->add_alive_server($server);
      if ( $server->{not_slave} eq '0' && !$server->{orig_master} ) {
        if ( !$server->is_sql_thread_error() && !$server->{lack_relay_log} ) {
          $self->add_alive_slave($server);
        }
        else {
          $self->add_failed_slave($server);
        }
      }
}
(2)Latest 數組
在 alive_slaves數組中選取 relaylog最新的 server,這個數組如果有多個 server,則 server的 Read_master_log_pos,master_log_file一定相等(此段代碼在 ServerManager.pm: identify_latest_slaves函數)
 
(3)Perf 數組
這個無需多解釋,就是MHA配置文件中配置了 candidate_master的值,這個可以大于 1哦
 
(4)Bad 數組: ( 代碼見: ServerManager.pm:get_bad_candidate_masters)
1) 檢測有故障的server
 
2) MHA 配置文件設置了 no_master 的 server
 
3)log_bin 沒有打開的server
 
4) 版本不兼容的server (高版本復制到低版本是沒問題的,但是如果低版本的選為為主庫,嘿嘿)
 
5) 復制落后太多的server
 
二 、MHA 主庫的選舉
(1) 指定主庫切換的,優先級最高(通常這是在手動切換)
 
(2) 如果server 在 latest 數組中,且在 perf 數組中,則優先返回
 
(3) 如果server 在 alive_servers 數組中,且在 perf 數組中,則優先返回
 
(4) 如果server 在 lastest 中,則優先返回
 
(5) 如果server 在 alive_servers 中,則返回
 
(6) 否則選舉失敗
 
這里優先級為1->6,具體實現在 (ServerManager.pm: select_new_master)
 
 
sub select_new_master {
  my $self                    = shift;
  my $prio_new_master_host    = shift;
  my $prio_new_master_port    = shift;
  my $check_replication_delay = shift;
  $check_replication_delay = 1 if ( !defined($check_replication_delay) );
 
  my $log    = $self->{logger};
  my @latest = $self->get_latest_slaves();
  my @slaves = $self->get_alive_slaves();
 
  my @pref = $self->get_candidate_masters();
  my @bad =
    $self->get_bad_candidate_masters( $latest[0], $check_replication_delay );
  #切換指定了master,即優先級最高的
  if ( $prio_new_master_host && $prio_new_master_port ) {
    my $new_master =
      $self->get_alive_server_by_hostport( $prio_new_master_host,
      $prio_new_master_port );
    if ($new_master) {
      my $a = $self->get_server_from_by_id( /@bad, $new_master->{id} );
      unless ($a) {
        $log->info("$prio_new_master_host can be new master.");
        return $new_master;
      }
      else {
        $log->error("$prio_new_master_host is bad as a new master!");
        return;
      }
    }
    else {
      $log->error("$prio_new_master_host is not alive!");
      return;
 
  # none of latest servers can not be a master
  $log->info(" Searching from all slaves..");
  foreach my $s (@slaves) {
    my $a = $self->get_server_from_by_id( /@bad, $s->{id} );
    return $s unless ($a);
  }
  $log->info("  Not found.");
 
  return;

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲最新视频在线| 国产69精品久久久久久| 成人妇女淫片aaaa视频| 欧美另类暴力丝袜| 欧美老女人在线视频| 理论片在线不卡免费观看| 亚洲午夜未满十八勿入免费观看全集| 黑人巨大精品欧美一区免费视频| 日韩有码在线电影| 国产在线拍揄自揄视频不卡99| 国产激情综合五月久久| 亚洲精品久久7777777| 亚洲娇小xxxx欧美娇小| 亚洲国产97在线精品一区| 久久99精品国产99久久6尤物| 最近日韩中文字幕中文| 国产丝袜一区视频在线观看| 国产精选久久久久久| 日本高清视频精品| 久久天天躁狠狠躁老女人| 亚洲香蕉在线观看| 91精品啪aⅴ在线观看国产| 欧美中文字幕在线| 精品国产91久久久久久老师| 国产激情综合五月久久| 亚洲精品国产免费| 夜夜嗨av一区二区三区四区| 亚洲精品一区二区三区不| 日本一欧美一欧美一亚洲视频| 日韩电影在线观看免费| 中文字幕欧美视频在线| 在线播放国产一区二区三区| 自拍亚洲一区欧美另类| 日韩成人在线视频网站| 成人免费视频在线观看超级碰| 欧美成人合集magnet| 亚洲乱码一区av黑人高潮| 欧美另类在线观看| 欧美激情精品久久久久久变态| 久久精品国产清自在天天线| 亚洲伊人成综合成人网| 久久电影一区二区| 国产欧美在线播放| 亚洲综合在线中文字幕| 亚洲影院色在线观看免费| 欧美日韩激情小视频| 国产亚洲精品一区二区| 日韩精品免费观看| **欧美日韩vr在线| 欧美精品日韩三级| 亚洲自拍在线观看| 一本色道久久综合狠狠躁篇的优点| 国产一区深夜福利| 精品调教chinesegay| 久久久久久久999| 免费不卡欧美自拍视频| 欧美久久精品一级黑人c片| 久久精品久久久久久| 日韩一区二区福利| 欧美综合第一页| 日韩中文av在线| 亚洲欧美另类人妖| 日韩最新免费不卡| 欧美日韩一区二区精品| 日韩经典中文字幕在线观看| 97精品国产91久久久久久| 亚洲色图25p| 欧美做爰性生交视频| 亚洲免费人成在线视频观看| 亚洲欧美日韩一区二区三区在线| 欧美日本亚洲视频| 欧美一乱一性一交一视频| 亚洲国产一区二区三区在线观看| 亚洲欧美制服中文字幕| 国产婷婷色综合av蜜臀av| 欧美激情一区二区三区高清视频| 国产亚洲精品日韩| 最近2019免费中文字幕视频三| 亚洲福利视频网站| 97国产精品视频| www.亚洲免费视频| 日韩av观看网址| 亚洲免费av网址| 亚洲欧美精品一区| 国产精品久久久久aaaa九色| 国产91av在线| 在线国产精品播放| 欧美视频在线视频| 亚洲精品免费一区二区三区| 国产亚洲精品美女久久久久| 欧美激情性做爰免费视频| 国产欧美精品在线| 亚洲淫片在线视频| 538国产精品一区二区在线| 国产欧美日韩中文字幕| 日韩美女写真福利在线观看| 欧美最猛性xxxx| 国产午夜精品视频| 88国产精品欧美一区二区三区| 久久国产视频网站| 97视频在线播放| 98精品国产高清在线xxxx天堂| 69av成年福利视频| 久久久噜噜噜久久中文字免| 精品毛片网大全| 成人做爰www免费看视频网站| 国产精品视频播放| 日韩av网站在线| 国产精品黄色影片导航在线观看| 欧美另类99xxxxx| 亚洲欧美日韩精品久久亚洲区| 国内精品免费午夜毛片| 亚洲韩国日本中文字幕| 精品国产自在精品国产浪潮| 91精品久久久久久综合乱菊| 91极品女神在线| 午夜精品一区二区三区在线视| 91嫩草在线视频| 国内精品国产三级国产在线专| 2019中文字幕全在线观看| 国产精品女视频| 亚洲精品久久久久| 97精品国产97久久久久久| 原创国产精品91| 欧美成人精品激情在线观看| 久久久www成人免费精品张筱雨| 亚洲国产精品人人爽夜夜爽| 日韩精品极品在线观看播放免费视频| 91精品国产91久久久| 国产伦精品免费视频| 国产精品丝袜高跟| 日韩精品免费在线播放| 日韩大片在线观看视频| 日韩av中文字幕在线播放| 亚洲天堂日韩电影| 亚洲欧美激情四射在线日| 97成人精品视频在线观看| 亚洲精品欧美一区二区三区| 91精品久久久久久久久青青| 亚洲天堂影视av| 69视频在线播放| 日韩激情视频在线| 国产99在线|中文| 久久伊人精品视频| 欧美激情中文字幕乱码免费| 日韩av中文字幕在线播放| 欧美日韩在线观看视频小说| 自拍亚洲一区欧美另类| 亚洲aⅴ男人的天堂在线观看| 国产成人精品日本亚洲| 欧美日韩成人在线观看| 国产精品 欧美在线| 欧美性生交xxxxxdddd| 国产精品久久久久久av下载红粉| 亚洲乱码一区av黑人高潮| 国产精品入口免费视频一| 中文字幕亚洲天堂| 久久精品美女视频网站| 精品久久久av| 97免费视频在线播放| 2019国产精品自在线拍国产不卡| 亚洲精品免费av| 中文字幕久热精品视频在线| 国产99视频精品免视看7|