1. Metastore:Hive Metastore 是 Hive 中的一个关键组件,用于存储 Hive 元数据信息。元数据信息包括数据库、表、分区、列、表的存储格式、分隔符等信息。Metastore 通常与关系型数据库(如 MySQL、PostgreSQL 等)配合使用,用于保证元数据的持久化存储和数据的持久性。
2. Driver:Hive Driver 是 Hive 查询的控制中心,负责解析用户提交的 HiveQL 查询语句,生成逻辑查询计划,并将计划转化为物理执行计划。Driver 还负责与 Metastore 交互,获取元数据信息用于查询执行。最后,Driver 还负责将物理执行计划提交给 Executor 进行实际的查询执行。
3. Executor:Hive Executor 是 Hive 查询的执行引擎,负责执行 Driver 生成的物理执行计划。Executor 主要包括 TaskTracker 和 Task 两个组件。TaskTracker 负责将任务分发给可用的计算节点进行执行,而 Task 负责具体的任务执行,如扫描数据、计算等。Executor 还负责将执行结果返回给 Driver。
总的来说,Metastore 负责存储元数据信息,Driver 负责查询计划的生成和任务调度,Executor 负责实际的查询执行。这三个组件共同协作,实现了 Hive 查询的功能。