ObsFile
Obs 文件源连接器
支持这些引擎
Spark
Flink
Seatunnel Zeta
关键特性
使用二进制文件格式读写任何格式的文件,例如视频、图片等。简而言之,任何文件都可以同步到目标位置。
在一次 pollNext 调用中读取分割中的所有数据。读取哪些分割将保存在快照中。
文件格式类型
- text
- csv
- parquet
- orc
- json
- excel
- markdown
描述
从华为云 OBS 文件系统读取数据。
如果您使用 spark/flink,为了使用此连接器,您必须确保您的 spark/flink 集群已集成 hadoop。测试的 hadoop 版本是 2.x。
如果您使用 SeaTunnel 引擎,它会在您下载和安装 SeaTunnel 引擎时自动集成 hadoop jar。您可以检查 ${SEATUNNEL_HOME}/lib 下的 jar 包来确认这一点。
我们为了支持更多文件类型做了一些权衡,所以我们使用 HDFS 协议来内部访问 OBS,此连接器需要一些 hadoop 依赖项。 它仅支持 hadoop 版本 2.9.X+。
必需的 Jar 列表
| jar | 支持的版本 | maven |
|---|---|---|
| hadoop-huaweicloud | 支持版本 >= 3.1.1.29 | 下载 |
| esdk-obs-java | 支持版本 >= 3.19.7.3 | 下载 |
| okhttp | 支持版本 >= 3.11.0 | 下载 |
| okio | 支持版本 >= 1.14.0 | 下载 |
请下载对应 'Maven' 的支持列表,并将其复制到 '$SEATUNNEL_HOME/plugins/jdbc/lib/' 工作目录。
并将所有 jar 复制到 $SEATUNNEL_HOME/lib/
选项
| 参数名 | 类型 | 必须 | 默认值 | 描述 |
|---|---|---|---|---|
| path | string | 是 | - | 目标目录路径 |
| file_format_type | string | 是 | - | 文件类型 |
| bucket | string | 是 | - | OBS 文件系统的桶地址,例如:obs://obs-bucket-name |
| access_key | string | 是 | - | OBS 文件系统的访问密钥 |
| access_secret | string | 是 | - | OBS 文件系统的访问密钥 |
| endpoint | string | 是 | - | OBS 文件系统的端点 |
| read_columns | list | 是 | - | 数据源的读取列列表 |
| delimiter | string | 否 | \001 | 字段分隔符 |
| row_delimiter | string | 否 | \n | 行分隔符 |
| parse_partition_from_path | boolean | 否 | true | 控制是否从文件路径解析分区键和值 |
| skip_header_row_number | long | 否 | 0 | 跳过前几行,但仅适用于 txt 和 csv。 |
| date_format | string | 否 | yyyy-MM-dd | 日期类型格式 |
| datetime_format | string | 否 | yyyy-MM-dd HH:mm:ss | 日期时间类型格式 |
| time_format | string | 否 | HH:mm:ss | 时间类型格式 |
| quote_char | string | 否 | " | 用于包裹 CSV 字段的单字符,可保证包含逗号、换行符或引号的字段被正确解析。 |
| escape_char | string | 否 | - | 用于在 CSV 字段内转义引号或其他特殊字符,使其不会结束字段。 |
file_format_type [string]
文件类型,支持以下文件类型:
text csv parquet orc json excel markdown
如果您将文件类型指定为 markdown,SeaTunnel 可以解析 markdown 文件并提取结构化数据。
markdown 解析器提取各种元素,包括标题、段落、列表、代码块、表格等。
每个元素都转换为具有以下架构的行:
element_id:元素的唯一标识符element_type:元素类型(Heading、Paragraph、ListItem 等)heading_level:标题级别(1-6,非标题元素为 null)text:元素的文本内容page_number:页码(默认:1)position_index:文档中的位置索引parent_id:父元素的 IDchild_ids:子元素 ID 的逗号分隔列表
当 markdown_rag_metadata_enabled 设置为 true 时,SeaTunnel 会在 child_ids 之后追加以下 RAG 元数据字段:
source_uri:源文件路径或 URIdocument_id:由source_uri派生的稳定文档标识符chunk_id:由文档标识、chunk 顺序和内容哈希派生的稳定 chunk 标识符chunk_index:解析后文档中的一基 chunk 顺序content_hash:已输出text值的 SHA-256 哈希
该选项默认值为 false,因此只有显式启用后才会改变原始 Markdown schema。
注意:Markdown 格式仅支持读取,不支持写入。