源端为对象存储
JSON样例
"from-config-values": { "configs": [ { "inputs": [ { "name": "fromJobConfig.bucketName", "value": "cdm-est" }, { "name": "fromJobConfig.inputDirectory", "value": "/obsfrom/varchar.txt" }, { "name": "fromJobConfig.inputFormat", "value": "CSV_FILE" }, { "name": "fromJobConfig.columnList", "value": "1&2&3" }, { "name": "fromJobConfig.fieldSeparator", "value": "," }, { "name": "fromJobConfig.quoteChar", "value": "false" }, { "name": "fromJobConfig.regexSeparator", "value": "false" }, { "name": "fromJobConfig.firstRowAsHeader", "value": "false" }, { "name": "fromJobConfig.encodeType", "value": "UTF-8" }, { "name": "fromJobConfig.fromCompression", "value": "NONE" }, { "name": "fromJobConfig.splitType", "value": "FILE" } ], "name": "fromJobConfig" } ] }
参数说明
参数 |
是否必选 |
类型 |
说明 |
---|---|---|---|
fromJobConfig.bucketName |
是 |
String |
对象存储的桶名。 |
fromJobConfig.inputDirectory |
是 |
String |
抽取文件的路径。支持输入多个文件路径(最多50个),默认以“|”分隔,也可以自定义文件分隔符,例如:“FROM/example.csv|FROM/b.txt”。 |
fromJobConfig.inputFormat |
是 |
枚举 |
传输数据时所用的文件格式,目前支持以下文件格式:
当选择“BINARY_FILE”时,目的端也必须为文件系统。 |
fromJobConfig.lineSeparator |
否 |
String |
文件中的换行符,默认自动识别“\n”、“\r”或“\r\n”,例如:“\n”。 |
fromJobConfig.columnList |
否 |
String |
需要抽取的列号,列号之间使用“&”分割,并由小到大排序,例如:“1&3&5”。 |
fromJobConfig.lineSeparator |
否 |
String |
换行符,当文件格式为“CSV_FILE”时此参数有效,默认值为:“\r\n”。 |
fromJobConfig.regexSeparator |
否 |
Boolean |
是否使用正则表达式分割字段,当文件格式为“CSV_FILE”时此参数有效。 |
fromJobConfig.regex |
否 |
String |
正则表达式,当选择使用正则表达式分割字段时,此参数有效。 |
fromJobConfig.fieldSeparator |
否 |
String |
字段分隔符,当文件格式为“CSV_FILE”时此参数有效,默认值为:“,”。 |
fromJobConfig.quoteChar |
否 |
Boolean |
是否使用包围符,选择“true”时,包围符内的字段分隔符会被视为字符串值的一部分,目前CDM默认的包围符为:"。 |
fromJobConfig.firstRowAsHeader |
否 |
Boolean |
是否默认首行为标题行,当文件格式为“CSV_FILE”时此参数有效。在迁移CSV文件到表时,CDM默认是全部写入,当该参数选择“true”时,CDM会将CSV文件的第一行数据作为标题行,不写入目的端的表。 |
fromJobConfig.fromCompression |
否 |
枚举 |
压缩格式,当文件格式为“CSV_FILE”或“JSON”时此参数有效。选择对应压缩格式的源文件:
|
fromJobConfig.jsonReferenceNode |
否 |
String |
记录节点,当文件格式为“JSON_FILE”时此参数有效。对该JSON节点下的数据进行解析,如果该节点对应的数据为JSON数组,那么系统会以同一模式从该数组中提取数据。多层嵌套的JSON节点以字符“.”分割,例如:“data.list”。 |
fromJobConfig.encodeType |
否 |
String |
编码类型,例如:“UTF_8”或“GBK”。 |
fromJobConfig.fromFileOpType |
否 |
枚举 |
源文件处理方式,作业完成后对源端文件的操作,支持重命名或删除源端文件。 |
fromJobConfig.useMarkerFile |
否 |
Boolean |
选择是否开启作业标识文件的功能。当源端路径下存在启动作业的标识文件时才启动作业,否则会挂起等待一段时间,等待时长在下方“fromJobConfig.waitTime”(等待时间)参数中配置。 |
fromJobConfig.markerFile |
否 |
String |
启动作业的标识文件名。指定文件后,只有在源端路径下存在该文件的情况下才会运行任务,不指定时默认不启用该功能,例如:“ok.txt”。 |
fromJobConfig.waitTime |
否 |
String |
选择开启作业标识文件的功能时,如果源路径下不存在启动作业的标识文件,作业挂机等待的时长,当超时后任务会失败。 等待时间设置为0时,当源端路径下不存在标识文件,任务会立即失败。 单位:秒。 |
fromJobConfig.filterType |
否 |
枚举 |
选择过滤器类型:
|
fromJobConfig.pathFilter |
否 |
String |
路径过滤器,过滤类型为通配符时配置,用于过滤文件目录,例如:“*input”。 |
fromJobConfig.fileFilter |
否 |
String |
文件过滤器,过滤类型为通配符时配置,用于过滤目录下的文件,支持配置多个文件,中间使用“,”分隔,例如:“*.csv,*.txt”。 |
fromJobConfig.startTime |
否 |
String |
“过滤类型”选择“时间过滤器”时,可以指定一个时间值,当文件的修改时间大于该时间才会被传输,输入的时间格式需为“yyyy-MM-dd HH:mm:ss”。 该参数支持配置为时间宏变量,例如${timestamp(dateformat(yyyy-MM-dd HH:mm:ss,-90,DAY))}表示:只迁移最近90天内的文件。 |
fromJobConfig.endTime |
否 |
String |
“过滤类型”选择“时间过滤器”时,可以指定一个时间值,当文件的修改时间小于该时间才会被传输,输入的时间格式需为“yyyy-MM-dd HH:mm:ss”。 该参数支持配置为时间宏变量,例如${timestamp(dateformat(yyyy-MM-dd HH:mm:ss))}表示:只迁移修改时间为当前时间以前的文件。 |
fromJobConfig.fileSeparator |
否 |
String |
“fromJobConfig.inputDirectory”(抽取文件的路径)参数中如果输入的是多个文件路径,CDM使用这里配置的文件分隔符来区分各个文件,默认为“|”。 |
fromJobConfig.decryption |
否 |
枚举 |
导出文件时,选择是否对已加密的文件解密后再导出,以及解密方式:
|
fromJobConfig.dek |
否 |
String |
数据解密密钥,密钥由长度64的十六进制数组成,且必须与加密时配置的“toJobConfig.dek”(导入时配置的数据加密密钥)一致。如果不一致系统不会报异常,只是解密出来的数据会错误。 |
fromJobConfig.iv |
否 |
String |
解密需要的初始化向量,初始化向量由长度32的十六进制数组成,且必须与加密时配置的“toJobConfig.iv”(导入时配置的初始化向量)一致。如果不一致系统不会报异常,只是解密出来的数据会错误。 |
fromJobConfig.md5FileSuffix |
否 |
String |
校验CDM抽取的文件,是否与源文件一致。 |