Spark SQL 源码分析(四):SessionCatalog

栏目: 编程工具 · 发布时间: 6年前

SessionCatalog 是底层元数据(基于内存和基于 Hive)的代理,同时也负责临时视图和函数的管理。

SessionCatalog 类图:

Spark SQL 源码分析(四):SessionCatalog

ExternalCatalog

ExternalCatalog 用于管理数据库、表、分区和函数,在 Spark SQL 中具体有两个实现:

InMemoryCatalog
HiveExternalCatalog

InMemoryCatalog

ExternalCatalog 基于内存(内部使用 scala.collection.mutable.HashMap )的实现,主要用于测试和探索。不建议用于生产环境。

HiveExternalCatalog

ExternalCatalog 基于 Hive(内部使用 org.apache.hadoop.hive.ql.metadata.Hive )的实现。

GlobalTempViewManager

GlobalTempViewManager 是线程安全的全局临时视图管理器,提供了对全局视图的原子操作,包括创建、更新和删除等。

内部由 scala.collection。mutable.HashMap[String, LogicalPlan] 实现。

FunctionResourceLoader

TODO

FunctionRegistry

提供了函数的注册、查找和删除等功能。

默认实现类 org.apache.spark.sql.catalyst.analysis.SimpleFunctionRegistry

基于 Spark 2.3.0 版本


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C++程序设计语言

C++程序设计语言

Bjarne Stroustrup / 裘宗燕 / 机械工业出版社 / 2010-3-1 / 99.00元

本书是在C++语言和程序设计领域具有深远影响、畅销不衰的著作,由C++语言的设计者编写,对C++语言进行了最全面、最权威的论述,覆盖标准C++以及由C++所支持的关键性编程技术和设计技术。本书英文原版一经面世,即引起业内人士的高度评价和热烈欢迎,先后被翻译成德、希、匈、西、荷、法、日、俄、中、韩等近20种语言,数以百万计的程序员从中获益,是无可取代的C++经典力作。 在本书英文原版面世10年......一起来看看 《C++程序设计语言》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试