美文网首页Spark Multi Tenancy
Kyuubi服务源码解析:KyuubiServer

Kyuubi服务源码解析:KyuubiServer

作者: 此间少年仍犹在 | 来源:发表于2018-05-08 21:27 被阅读67次

  Kyuubi服务与HiveServer2服务非常相似,在Kyuubi中很多类的设计和代码逻辑都参照了HiveServer2(Spark SQL Thrift Server也是同样的道理)。
  HiveServer2服务启动的源码解析参见:
  Hive源码剖析之HiveServer2服务启动过程
  Spark SQL Thrift Server服务启动的源码解析参见以下两处文章:
  SparkSQL Hive ThriftServer 源码解析:Intro
  Spark SQL源码走读(一):HiveThriftServer2:Intro

(注:以下代码模块中,英文注释皆为作者注释,中文注释是我自己加上的)

KuubiServer.scala

  • KuubiServer类声明及成员
/**
 * Main entrance of Kyuubi Server
 */
private[kyuubi] class KyuubiServer private(name: String)
  extends CompositeService(name) with Logging {
  //BackendService服务
  private[this] var _beService: BackendService = _
  def beService: BackendService = _beService
  //FrontendService服务
  private[this] var _feService: FrontendService = _
  def feService: FrontendService = _feService
  ***后续代码省略***
}

  简单介绍一下KyuubiServer中两个很重要的成员FrontendServiceBackendService:FrontendService负责维护与客户端的连接,与客户端进行交互,将客户端的SQL请求转发至FrontendService;BackendService负责执行SQL并将执行结果返回给FrontendService。FrontendService最后将结果返回至客户端。

  • main方法
def main(args: Array[String]): Unit = {
    SparkUtils.initDaemon(logger)
    //加载配置
    val conf = new SparkConf(loadDefaults = true)
    setupCommonConfig(conf)

    try {
      val server = new KyuubiServer()
      //对各种服务进行初始化
      server.init(conf)
      //启动各种服务
      server.start()
      info(server.getName + " started!")
      if (HighAvailabilityUtils.isSupportDynamicServiceDiscovery(conf)) {
        info(s"HA mode: start to add this ${server.getName} instance to Zookeeper...")
        HighAvailabilityUtils.addServerInstanceToZooKeeper(server)
      }
    } catch {
      case e: Exception =>
        error("Error starting Kyuubi Server", e)
        System.exit(-1)
    }
  • init方法
  override def init(conf: SparkConf): Unit = synchronized {
    this.conf = conf
    _beService = new BackendService()
    _feService = new FrontendService(_beService)
    //将BackendService和FrontendService服务加入serviceList中
    addService(_beService)
    addService(_feService)
    //调用父类CompositeService的init方法
    super.init(conf)
    SparkUtils.addShutdownHook {
      () => this.stop()
    }
  }

CompositeService的init方法:

  override def init(conf: SparkConf): Unit = {
    //依次调用serviceList中各个服务的init方法
    for (service <- serviceList) {
      service.init(conf)
    }
    super.init(conf)
  }
  • start方法
  override def start(): Unit = {
    //遍历serviceList中所有的服务并依次启动
    serviceList.zipWithIndex.foreach { case (service, i) =>
      try {
        service.start()
      } catch {
        case e: Throwable =>
          error("Error starting services " + getName, e)
          stop(i)
          throw new ServiceException("Failed to Start " + getName, e)
      }
    }
    super.start()
  }

  调用各个服务的init和start方法时,最终都会调用AbstractService的init和start方法(这些服务类要么直接继承AbstractService,要么继承CompositeService。而CompositeService又继承自AbstractService)。

AbstractService的init和start方法:

  override def init(conf: SparkConf): Unit = {
    ensureCurrentState(State.NOT_INITED)
    this.conf = conf
    changeState(State.INITED)
    info("Service: [" + getName + "] is initialized.")
  }

  override def start(): Unit = {
    startTime = System.currentTimeMillis
    ensureCurrentState(State.INITED)
    changeState(State.STARTED)
    info("Service: [" + getName + "] is started.")
  }

  对照Kyuubi服务启动日志,可以看到KyuubiServer依次启动的服务有:KyuubiServer、OperationManager、SessionManager、BackendService和FrontendService(至于为什么也启动了OperationManager和SessionManager服务,在后续解析BackendService的源码时会提及)。

Kyuubi服务启动日志

相关文章

网友评论

    本文标题:Kyuubi服务源码解析:KyuubiServer

    本文链接:https://www.haomeiwen.com/subject/akiwrftx.html