成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

詳解租約機制以及在hbase中的應(yīng)用

詳解租約機制以及在hbase中的應(yīng)用

成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),饒平企業(yè)網(wǎng)站建設(shè),饒平品牌網(wǎng)站建設(shè),網(wǎng)站定制,饒平網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,饒平網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

為什么需要Lease

分布式系統(tǒng)中為什么需要租約機制,這是因為在分布式系統(tǒng),為了保證服務(wù)的高可用,需要在服務(wù)發(fā)生故障的時候及時啟動另外一個服務(wù)實例以替換故障服務(wù)。這樣就需要在服務(wù)端和客戶端或者服務(wù)端和控制中心維持一個心跳信息,用于服務(wù)進程向控制中心匯報當(dāng)前自己的健康情況,如果控制中心在一段時間收不到服務(wù)進程上報的心跳,則會啟動新的進程繼續(xù)對外提供服務(wù)。

但是,由于實際網(wǎng)絡(luò)情況的復(fù)雜性,控制中心無法收到心跳時不能準(zhǔn)確地判斷究竟是服務(wù)故障了還是服務(wù)進程和控制中心之間的網(wǎng)絡(luò)發(fā)生了故障。這種情況下控制中心冒然地啟用新進程有可能會造成“雙主”這種情況出現(xiàn)。

為避免上述情況的發(fā)生引入了租約機制,此時服務(wù)節(jié)點持續(xù)向控制中心申請短時間租約,控制中心在已派發(fā)的租約過期之前,不會啟用新服務(wù)節(jié)點,而服務(wù)節(jié)點租約過期時若還無法從控制中心申請到新租約,自己中斷客戶鏈接。

此外,租約機制還可用于客戶端和服務(wù)端之間的解藕,避免客戶端進程失去響應(yīng)時,其占用的服務(wù)端資源長期得不到釋放進而影響到服務(wù)端的穩(wěn)定。

Lease的實現(xiàn)

在實際系統(tǒng)中,如果依賴一個中心結(jié)點向外發(fā)布lease存在很大的風(fēng)險,那就是如果該中心結(jié)點發(fā)生宕機或者網(wǎng)絡(luò)故障,那么服務(wù)節(jié)點由于接收不到新的租約那么會導(dǎo)致整個服務(wù)集群進入不可用狀態(tài)。因此,在實際使用中,對外提供lease服務(wù)的往往是由多個進程實例組成的另外一套集群,該集群具有高可用性,可以對外提供lease服務(wù),比如zookeeper集群。

HRegionServer的租約Lease管理

租約線程的初始化

在HRegionServer的run主循環(huán)里會調(diào)用preRegistrationInitialization預(yù)先初始化一些線程,包括初始化集群連接信息setupClusterConnection()、healthCheckChore、pauseMonitor、initializeZookeeper以及initializeThreads()。

其中在initializeThreads()中會初始化各類線程,這些線程包括了這臺regionServer的lease線程:

this.compactionChecker = new CompactionChecker(this, this.threadWakeFrequency, this); //檢查合并請求 
this.periodicFlusher = new PeriodicMemstoreFlusher(this.threadWakeFrequency, this);  //周期性地檢查memstore的flush請求 
this.leases = new Leases(this.threadWakeFrequency); 

 Leases類的定義如下,它繼承了HasThread這個抽象類,并定義了如下幾個主要的成員變量:

public static final int MIN_WAIT_TIME = 100; 
private final Map<String, Lease> leases = new ConcurrentHashMap<String, Lease>(); 
 
protected final int leaseCheckFrequency; 
protected volatile boolean stopRequested = false; 

 其中Map型成員變量leases負責(zé)管理該regionserver進程中的lease實例,我們看看lease類都定義了哪些變量:

private final String leaseName; 
private final LeaseListener listener; 
private int leaseTimeoutPeriod; 
private long expirationTime; 

 leaseTimeoutPeriod是租約時間,expirationTime會在lease被創(chuàng)建時被置位為系統(tǒng)時間與leaseTimeoutPeriod之和,用于周期性地計算該租約已經(jīng)被使用多長時間,如果租約已經(jīng)超過了leaseTimeoutPeriod定義的到期時間,則會觸發(fā)一個expired事件,LeaseListener會監(jiān)聽該事件并調(diào)用leaseExpired方法,不同類型的lease都會繼承LeaseListener接口并實現(xiàn)自己的leaseExpired方法,如下所示是scan lease對該方法的實現(xiàn):

@Override 
public void leaseExpired() {    //處理租約過期 
  RegionScannerHolder rsh = scanners.remove(this.scannerName); 
  if (rsh != null) { 
   RegionScanner s = rsh.s; 
   LOG.info("Scanner " + this.scannerName + " lease expired on region " 
     + s.getRegionInfo().getRegionNameAsString()); 
   try { 
    Region region = regionServer.getRegion(s.getRegionInfo().getRegionName()); 
    if (region != null && region.getCoprocessorHost() != null) { 
     region.getCoprocessorHost().preScannerClose(s); 
    } 
 
    s.close(); 
    if (region != null && region.getCoprocessorHost() != null) { 
     region.getCoprocessorHost().postScannerClose(s); 
    } 
   } catch (IOException e) { 
    LOG.error("Closing scanner for " 
     + s.getRegionInfo().getRegionNameAsString(), e); 
   } 
  } else { 
   LOG.warn("Scanner " + this.scannerName + " lease expired, but no related" + 
    " scanner found, hence no chance to close that related scanner!"); 
  } 
 } 

 客戶端的scan請求是分解成多次RPC請求發(fā)到服務(wù)端的,分解的次數(shù)是scan的總數(shù)據(jù)量與客戶端setCache兩者的比值。每個scan請求發(fā)到服務(wù)端后會租用一個scanner,用于當(dāng)前的scan結(jié)束后,后續(xù)的scan可以直接復(fù)用已有的資源,但是為防止scanner長期占用服務(wù)端資源,通過租約管理,關(guān)閉不再使用的scanner。

OK,回到前面的Leases類,看看它是如何管理regionServer進程中的各個lease的,這部分邏輯在它覆寫的run方法中:

public void run() { 
  long toWait = leaseCheckFrequency; 
  Lease nextLease = null; 
  long nextLeaseDelay = Long.MAX_VALUE; 
 
  while (!stopRequested || (stopRequested && !leases.isEmpty()) ) { 
 
   //睡眠一段時間 
 
   nextLease = null; 
   nextLeaseDelay = Long.MAX_VALUE; 
   for (Iterator<Map.Entry<String, Lease>> it = leases.entrySet().iterator(); it.hasNext();) { 
    Map.Entry<String, Lease> entry = it.next(); 
    Lease lease = entry.getValue(); 
    long thisLeaseDelay = lease.getDelay(TimeUnit.MILLISECONDS); 
    if ( thisLeaseDelay > 0) { 
     if (nextLease == null || thisLeaseDelay < nextLeaseDelay) { 
      nextLease = lease; 
      nextLeaseDelay = thisLeaseDelay; 
     } 
    } else { 
     // A lease expired. Run the expired code before removing from map 
     // since its presence in map is used to see if lease exists still. 
     if (lease.getListener() == null) { 
      LOG.error("lease listener is null for lease " + lease.getLeaseName()); 
     } else { 
      lease.getListener().leaseExpired(); 
     } 
     it.remove(); 
    } 
   } 
  } 
  close(); 
 } 

 我們省略掉一些異常處理,在while的循環(huán)周期中會逐一便利map中管理的lease,計算每個lease的thisLeaseDelay以檢查改lease是否已經(jīng)過期。判斷l(xiāng)ease是否過期的方法很簡單,就是取出當(dāng)前時間與lease中定義的expirationTime做差,如果差值小于0,則說明該租約已經(jīng)到期,則調(diào)用lease中定義的leaseExpired方法,這與上面我們講過的關(guān)聯(lián)上了。其中thisLeaseDelay決定了下一次的lease檢查在多久之后發(fā)生,thisLeaseDelay的計算依據(jù)是選擇選取所有未過期lease中l(wèi)easeDelay最短的,通過thisLeaseDelay計算toWait時間,用于決定前面的睡眠時間。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

當(dāng)前題目:詳解租約機制以及在hbase中的應(yīng)用
URL分享:http://jinyejixie.com/article32/gphpsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、外貿(mào)建站、電子商務(wù)、網(wǎng)站設(shè)計公司、網(wǎng)站內(nèi)鏈、品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
洛南县| 屏东县| 郴州市| 综艺| 岳池县| 邯郸市| 铜鼓县| 全南县| 青州市| SHOW| 阳春市| 利津县| 右玉县| 惠水县| 美姑县| 衢州市| 黄大仙区| 冷水江市| 二手房| 丰城市| 麻江县| 沙湾县| 鄂尔多斯市| 正蓝旗| 金门县| 东兰县| 横山县| 时尚| 广西| 五台县| 高尔夫| 香格里拉县| 大同县| 石景山区| 阿拉善右旗| 蚌埠市| 抚远县| 临汾市| 阿勒泰市| 汶川县| 唐河县|