HDFS
此引擎通过允许在 ClickHouse 上管理 HDFS 上的数据,提供与 Apache Hadoop 生态系统的集成。该引擎与 File 和 URL 引擎类似,但提供了 Hadoop 特定的功能。
此功能不受 ClickHouse 工程师支持,并且已知质量不稳定。如果遇到任何问题,请自行修复并提交拉取请求。
用法
引擎参数
URI- HDFS 中整个文件的 URI。URI的路径部分可以包含通配符。在这种情况下,表将是只读的。format- 指定可用文件格式之一。进行SELECT查询时,格式必须支持输入,而进行INSERT查询时,格式必须支持输出。可用格式列在 Formats 部分。- [PARTITION BY expr]
PARTITION BY
PARTITION BY — 可选。在大多数情况下,您无需分区键,如果需要,通常不需要比按月更细粒度的分区键。分区不会加速查询(与 ORDER BY 表达式相反)。您绝不应使用过于细粒度的分区。不要按客户端标识符或名称对数据进行分区(相反,应将客户端标识符或名称设为 ORDER BY 表达式中的第一列)。
按月分区时,使用 toYYYYMM(date_column) 表达式,其中 date_column 是类型为 Date 的日期列。此处的分区名称具有 "YYYYMM" 格式。
示例:
1. 设置 hdfs_engine_table 表:
2. 填充文件:
3. 查询数据:
实现细节
-
读写可以并行进行。
-
不支持:
ALTER和SELECT...SAMPLE操作。- 索引。
- 零拷贝 复制是可能的,但不建议使用。
备注零拷贝复制在 ClickHouse 版本 22.8 及更高版本中默认禁用。此功能不建议用于生产环境。
路径中的通配符
多个路径组件可以具有通配符。要被处理的文件必须存在并符合整个路径模式。文件的列出是在 SELECT 时确定的(而不是在 CREATE 时)。
*— 替代除/外的任何数量的任意字符,包括空字符串。?— 替代任何单个字符。{some_string,another_string,yet_another_one}— 替代任何字符串'some_string', 'another_string', 'yet_another_one'。{N..M}— 替代从 N 到 M 范围内的任何数字,包括两个边界。
使用 {} 的结构类似于 remote 表函数。
示例
-
假设我们在 HDFS 上有几个 TSV 格式的文件,URI 如下:
- 'hdfs://hdfs1:9000/some_dir/some_file_1'
- 'hdfs://hdfs1:9000/some_dir/some_file_2'
- 'hdfs://hdfs1:9000/some_dir/some_file_3'
- 'hdfs://hdfs1:9000/another_dir/some_file_1'
- 'hdfs://hdfs1:9000/another_dir/some_file_2'
- 'hdfs://hdfs1:9000/another_dir/some_file_3'
-
有几种方法可以创建一个由所有六个文件组成的表:
另一种方法:
表包含两个目录中的所有文件(所有文件应满足查询中描述的格式和模式):
如果文件列表包含带有前导零的数字范围,请分别为每个数字单独使用大括号构造,或使用 ?。
示例
创建一个文件名为 file000、file001、...、file999 的表:
配置
与 GraphiteMergeTree 类似,HDFS 引擎支持使用 ClickHouse 配置文件进行扩展配置。您可以使用两个配置键:全局 (hdfs) 和用户级别 (hdfs_*)。全局配置首先应用,然后应用用户级别的配置(如果存在)。
配置选项
libhdfs3 支持的
| 参数 | 默认值 |
|---|---|
| rpc_client_connect_tcpnodelay | true |
| dfs_client_read_shortcircuit | true |
| output_replace-datanode-on-failure | true |
| input_notretry-another-node | false |
| input_localread_mappedfile | true |
| dfs_client_use_legacy_blockreader_local | false |
| rpc_client_ping_interval | 10 * 1000 |
| rpc_client_connect_timeout | 600 * 1000 |
| rpc_client_read_timeout | 3600 * 1000 |
| rpc_client_write_timeout | 3600 * 1000 |
| rpc_client_socket_linger_timeout | -1 |
| rpc_client_connect_retry | 10 |
| rpc_client_timeout | 3600 * 1000 |
| dfs_default_replica | 3 |
| input_connect_timeout | 600 * 1000 |
| input_read_timeout | 3600 * 1000 |
| input_write_timeout | 3600 * 1000 |
| input_localread_default_buffersize | 1 * 1024 * 1024 |
| dfs_prefetchsize | 10 |
| input_read_getblockinfo_retry | 3 |
| input_localread_blockinfo_cachesize | 1000 |
| input_read_max_retry | 60 |
| output_default_chunksize | 512 |
| output_default_packetsize | 64 * 1024 |
| output_default_write_retry | 10 |
| output_connect_timeout | 600 * 1000 |
| output_read_timeout | 3600 * 1000 |
| output_write_timeout | 3600 * 1000 |
| output_close_timeout | 3600 * 1000 |
| output_packetpool_size | 1024 |
| output_heartbeat_interval | 10 * 1000 |
| dfs_client_failover_max_attempts | 15 |
| dfs_client_read_shortcircuit_streams_cache_size | 256 |
| dfs_client_socketcache_expiryMsec | 3000 |
| dfs_client_socketcache_capacity | 16 |
| dfs_default_blocksize | 64 * 1024 * 1024 |
| dfs_default_uri | "hdfs://localhost:9000" |
| hadoop_security_authentication | "simple" |
| hadoop_security_kerberos_ticket_cache_path | "" |
| dfs_client_log_severity | "INFO" |
| dfs_domain_socket_path | "" |
HDFS 配置参考 可能会解释一些参数。
ClickHouse 附加项
| 参数 | 默认值 |
|---|---|
| hadoop_kerberos_keytab | "" |
| hadoop_kerberos_principal | "" |
| libhdfs3_conf | "" |
限制
hadoop_security_kerberos_ticket_cache_path和libhdfs3_conf只能是全局的,而不是用户特定的。
Kerberos 支持
如果 hadoop_security_authentication 参数的值为 kerberos,ClickHouse 将通过 Kerberos 进行身份验证。
参数在 这里 可找到,hadoop_security_kerberos_ticket_cache_path 可能会有所帮助。
请注意,由于 libhdfs3 的限制,仅支持传统方法,数据节点之间的通信未通过 SASL 安全(HADOOP_SECURE_DN_USER 是此类安全方法的可靠指标)。参考 tests/integration/test_storage_kerberized_hdfs/hdfs_configs/bootstrap.sh。
如果指定了 hadoop_kerberos_keytab、hadoop_kerberos_principal 或 hadoop_security_kerberos_ticket_cache_path,则将使用 Kerberos 身份验证。在这种情况下,hadoop_kerberos_keytab 和 hadoop_kerberos_principal 是必需的。
HDFS Namenode HA 支持
libhdfs3 支持 HDFS namenode HA。
- 将
hdfs-site.xml从 HDFS 节点复制到/etc/clickhouse-server/。 - 在 ClickHouse 配置文件中添加以下部分:
- 然后在 HDFS URI 中使用
hdfs-site.xml的dfs.nameservices标签值作为 namenode 地址。例如,将hdfs://[email protected]:8020/abc/替换为hdfs://appadmin@my_nameservice/abc/。
虚拟列
_path— 文件的路径。类型:LowCardinality(String)。_file— 文件名。类型:LowCardinality(String)。_size— 文件大小(以字节为单位)。类型:Nullable(UInt64)。如果大小未知,值为NULL。_time— 文件的最后修改时间。类型:Nullable(DateTime)。如果时间未知,值为NULL。
存储设置
- hdfs_truncate_on_insert - 允许在插入前截断文件。默认禁用。
- hdfs_create_new_file_on_insert - 允许在每次插入时创建一个新文件(如果格式具有后缀)。默认禁用。
- hdfs_skip_empty_files - 允许在读取时跳过空文件。默认禁用。
另请参阅