用法
URI- HDFS 中文件的完整 URI。URI的路径部分可以包含通配符。在这种情况下,该表将为只读。格式- 指定一种可用的文件格式。要执行SELECT查询,该格式必须支持输入;而要执行INSERT查询,则必须支持输出。可用格式列在 格式 部分。- [PARTITION BY expr]
PARTITION BY
PARTITION BY — 可选。在大多数情况下,不需要分区键;即使需要,通常也不必将分区划分得比按月更细。分区不会加快查询速度 (这一点与 ORDER BY 表达式不同) 。切勿使用粒度过细的分区方式。不要按客户端标识符或名称对数据进行分区 (而应将客户端标识符或名称设为 ORDER BY 表达式中的第一列) 。
如果按月分区,请使用 toYYYYMM(date_column) 表达式,其中 date_column 是一个 Date 类型的日期列。这里的分区名称采用 "YYYYMM" 格式。
示例:
1. 设置 hdfs_engine_table 表:
实现细节
- 读取和写入可以并行进行。
- 不支持:
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 table function 类似。
示例
-
假设我们在 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 的文件:
配置
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 | "" |
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 的限制,目前仅支持较旧的方式,
datanode 通信不会受到 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
- 将
hdfs-site.xml从某个 HDFS 节点复制到/etc/clickhouse-server/。 - 在 ClickHouse 配置文件中添加以下内容:
- 然后使用
hdfs-site.xml中dfs.nameservices的值作为 HDFS URI 中的 NameNode 地址。例如,将hdfs://appadmin@192.168.101.11: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 - 如果 格式 带有 suffix,则允许在每次插入时创建新文件。默认禁用。
- hdfs_skip_empty_files - 允许在读取时跳过空文件。默认禁用。