HBase 0.1.0版本源码分析--Master启动流程

接触HBase2个月了,公司使用了0.92版本,大概浏览过代码,对于我等菜鸟来说过于复杂,入门甚难,故找来最原始的版本来看看,顺便瞻仰下当年大神的原迹。

原始版本可以在github上找到,在以后的几篇文章中笔者也将仔细的分析HBase中几个比较重要类的逻辑。

Master初始化

1.查看是hdfs文件系统,如果是则等待hdfs退出safemode

 this.fs = FileSystem.get(conf);
    if (this.fs instanceof DistributedFileSystem) {
      // Make sure dfs is not in safe mode
      String message = "Waiting for dfs to exit safe mode...";
      while (((DistributedFileSystem) fs).setSafeMode(
          FSConstants.SafeModeAction.SAFEMODE_GET)) {
        LOG.info(message);
        try {
          Thread.sleep(this.threadWakeFrequency);
        } catch (InterruptedException e) {
          //continue
        }
      }
    }

2.创建Root Meta Region ,创建Region过程比较复杂会另起文章分析

 	HRegion root = HRegion.createHRegion(HRegionInfo.rootRegionInfo,
              this.rootdir, this.conf);
          HRegion meta = HRegion.createHRegion(HRegionInfo.firstMetaRegionInfo,
            this.rootdir, this.conf);

          // Add first region from the META table to the ROOT region.
          HRegion.addRegionToMETA(root, meta);
          root.close();
          root.getLog().closeAndDelete();
          meta.close();
          meta.getLog().closeAndDelete();

3.初始化lease对象、Server对象、HServerAddress对象、HConnection对象

lease对象负责定时清除过期的任务,具体实现可以参考http://www.cnblogs.com/luweiseu/archive/2012/08/06/2625768.html

Server对象的功能是HBase的rpc,负责与其他server或者client进行rpc

HServerAddress类简单封装了InetSocketAddress对象

HConnection对象维护了servername-》ServerAddress的map,帮助master能够连接到任何一个server

4.启动RootScanner和MetaScanner线程,初始化Sleeper,准备对外服务。

Master主循环

1.启动master的诸多守护进程:RootScanner MetaScanner ServerLease infoServer(web展示页面)RPCServer

Threads.setDaemonThreadRunning(this.rootScannerThread,
        threadName + ".rootScanner");
      Threads.setDaemonThreadRunning(this.metaScannerThread,
        threadName + ".metaScanner");
      // Leases are not the same as Chore threads. Set name differently.
      this.serverLeases.setName(threadName + ".leaseChecker");
      this.serverLeases.start();
      // Put up info server.
      int port = this.conf.getInt("hbase.master.info.port", 60010);
      if (port >= 0) {
        String a = this.conf.get("hbase.master.info.bindAddress", "0.0.0.0");
        this.infoServer = new InfoServer(MASTER, a, port, false);
        this.infoServer.setAttribute(MASTER, this);
        this.infoServer.start();
      }
      // Start the server so everything else is running before we start
      // receiving requests.
      this.server.start();

2.主循环不停的从todoqueue里拿出regionserver的operation干活,如果没有活干就休息,如果收到shutdownrequest就进入shutdown master流程,主循环伪代码如下:

while (!closed.get()) {
      RegionServerOperation op = null;
      if (shutdownRequested && serversToServerInfo.size() == 0) {
        startShutdown();
        break;
      }
      if (op == null ) {
        try {
          op = toDoQueue.poll(threadWakeFrequency, TimeUnit.MILLISECONDS);
        } catch (InterruptedException e) {
          // continue
        }
        
      op.process();
    }




你可能感兴趣的:(master)