MaxCompute加速
Hologres与MaxCompute数据源底层无缝打通,深度融合,可双向直读对方存储,一键映射对方元数据,大大提升数据访问效率。本文为您介绍Hologres加速读写MaxCompute数据的相关能力及使用限制。
背景信息
大数据计算服务(MaxCompute)是一种快速、完全托管的EB级数据仓库,致力于批量结构化数据的存储和计算,提供海量数据仓库的解决方案及分析建模服务。详情请参见什么是MaxCompute。
Hologres是阿里巴巴自主研发的一站式实时数据仓库引擎(Real-Time Data Warehouse),支持海量数据的实时写入、实时更新、实时处理和实时分析。该引擎与MaxCompute原生深度集成,支持通过创建外部数据库和外部表的方式实现MaxCompute元数据的映射及查询加速,无需导入数据,即可通过一份存储快速获取查询结果并提供对外服务。此外,Hologres采用标准PostgreSQL协议,能够无缝对接PostgreSQL生态系统中的所有主流BI工具,详情请参见BI分析及可视化。
场景介绍
使用外表加速查询MaxCompute数据
在离线实时一体化方案中,最关键的是数据交换的简化,最好无需移动数据,一份存储即可支持离线与实时两种计算方式。外部表查询有效地解决了这一问题。
您可通过CREATE EXTERNAL DATABASE的方式整库映射MaxCompute内部Project下的Schema和表,也可以通过IMPORT FOREIGN SCHEMA方式批量创建外部表,同时对于仅需要加速查询少量MaxCompute表或者某张表中部分字段的场景,我们也提供了CREATE FOREIGN TABLE的方式,您可以根据业务特性和场景,选择合适的加速方式。
从Hologres V3.0 版本开始,通过外部表查询MaxCompute数据取消了一次查询扫描数据量不超过200GB、分区数不超过512个的限制,方便您更好地使用该服务。同时,放宽限制的大查询会消耗更多的Hologres实例资源,请您做好资源隔离,详情请参见计算组实例快速入门,或者对于偶发的大查询可以使用Serverless模式,详情请参见Serverless Computing。
MaxCompute数据导入Hologres
为了获取更好的查询性能,您也可以将数据导入Hologres,再进行查询。该方式可充分利用Hologres的索引能力和存储优化来进一步加速查询,来实现BI实时分析、高并发点查、多表复杂关联查询等场景,详情请参见MaxCompute数据导入Hologres。
Hologres数据导出至MaxCompute
在实际业务场景中,我们通常需要将Hologres实时写入的数据与经过聚合分析后的结果回写至MaxCompute,用来实现历史数据归档存储、冷热数据分层管理以及离线数仓数据回补等场景,您可通过INSERT INTO或INSERT OVERWRITE方式回写数据至MaxCompute。详情请参见导出至MaxCompute。
功能详情
Hologres加速MaxCompute外部表支持的具体能力如下:
Hologres版本号 | 支持的能力 | 描述 |
V3.0.7 | 支持通过CREATE EXTERNAL DATABASE的方式完整映射MaxCompute Project下的Schema和表。 | CREATE EXTERNAL DATABASE 用于在Hologres实例中创建一个外部数据库,来加载外部数据源的元数据到Hologres,方便在一个系统中同时管理内、外部数据,实现湖仓一体架构下统一的元数据管理。详情请参见CREATE EXTERNAL DATABASE。 |
取消外部表查询一次查询扫描数据量不超过200GB、分区数不超过512个的限制。 | 取消外部表查询限制,便于用户使用Hologres加速查询更大规模MaxCompute数据,同时提供计算组实例、Serverless方式以实现资源隔离,从而避免大查询消耗过多实例资源,影响其他查询和写入作业的执行。 | |
V2.2.1 | 外部表自动加载支持MaxCompute Schema(三层模型)。 | Schema是MaxCompute介于项目和表、资源、函数之间的概念,对表、资源及函数进行进一步归类。外部表自动加载详情请参见外部表自动加载(Auto Load)。 |
外部表自动加载支持元数据自动刷新。 | 无 | |
外部表自动加载支持MaxCompute外部表Schema Evolution。 | 在MaxCompute侧执行过删除列、修改列顺序、修改列类型等操作的表。详情请参见外部表自动加载(Auto Load)。 | |
支持通过SLR访问MaxCompute数据。 | 服务关联角色(ServiceLinkedRole,简称SLR)是一种可信实体为阿里云服务的RAM角色,旨在解决跨云服务的授权访问问题,详情请参见Hologres服务关联角色。 | |
V2.1 | 支持对MaxCompute三层模型指定Schema下的表进行数据写入。 | Schema是MaxCompute介于项目和表、资源、函数之间的概念,对表、资源及函数进行进一步归类。详情请参见Schema。 |
支持通过HoloWeb可视化访问MaxCompute三层模型指定Schema下的表。 | 详情请参见基于HoloWeb创建MaxCompute外部表。 | |
V2.0 | 升级MaxCompute加速引擎为HQE,改善兼容性与稳定性。 | 无 |
V1.3 | 支持通过外部表方式查询MaxCompute的Transactional表。 | 无 |
支持读取MaxCompute Schema Evolution状态表。 | 在MaxCompute侧执行过删除列、修改列顺序、修改列类型操作的表。 | |
Hologres和MaxCompute之间交互支持双签名认证。 | 详情请参见创建Hologres外部表(双签名模式)。 | |
支持访问MaxCompute BYOK方式加密的表。 | 详情请参见查询MaxCompute加密数据(BYOK模式)。 | |
V1.1.43 | 支持外部表自动加载,实现MaxCompute外部表的按需自动加载以及全量自动加载。 | 详情请参见外部表自动加载(Auto Load)。 |
注意事项
通过Hologres加速查询MaxCompute数据时,您需要注意如下内容:
由于跨地域查询存在较多网络不可靠因素,查询稳定性无法保障,请确保Hologres和MaxCompute处于同一地域。
Hologres只能加速查询MaxCompute的内部表,不能查询MaxCompute的外部表和VIEW。
MaxCompute的分区与Hologres无强映射关系,映射至Hologres之后均为普通字段,但可通过分区条件过滤查询。
暂不支持读取MaxCompute中Map、Struct类型的数据。
暂不支持读取MaxCompute侧使用DATETIME、TIMESTAMP、DECIMAL类型作为Cluster列的Range Cluster表数据。
仅支持读取MaxCompute标准存储数据,不支持读取低频存储和长期存储数据。