开发者社区 > 大数据与机器学习 > 正文

Flink 写入Doris数据异常

actual column number is less than schema column number.actual number: 28, column separator: [ ], line delimiter: [
], schema number: 29;
问题的关键是:表里的字段就是28个 并不是29个.报错显示29个
代码里修改过: executionBuilder.setDeletable(false); 没用
这个任务之前跑了大半年了

展开
收起
游客pmslgqfklqdm6 2024-05-13 17:36:04 244 0
1 条回答
写回答
取消 提交回答
  • 这个问题看起来是由于Flink作业在尝试写入Doris时,发现实际的列数(28)与预期的列数(29)不匹配。即使你确认表的字段数量是28个,报错信息仍然指出有29个。这里有几个可能的原因和解决方案:

    1. 代码或配置错误

      • 检查你的Flink作业代码,确保你没有在代码中硬编码了错误的列数。确保列的映射与Doris表的实际结构匹配。
      • 确认你的Flink连接器配置(如DorisSink)中指定的列数是否正确。
    2. 数据源问题

      • 如果你的Flink作业是从其他数据源读取数据,检查源头数据是否有可能包含额外的隐藏字段或者意外的分隔符导致多解析出一个字段。
    3. 版本更新

      • 如果这个任务之前一直正常运行,可能是Flink、Doris或连接器的某个更新导致了这个问题。检查最近是否有任何依赖库的升级。
    4. 临时性错误

      • 可能是短暂的网络问题或Doris服务端的瞬时状态导致的。尝试重启作业或稍后再试。
    5. 日志和调试

      • 查看Flink作业的完整日志,可能有更多的错误信息或堆栈跟踪可以帮助定位问题。
      • 在Doris端检查是否有相关的错误日志或警告。
    6. 连接器配置检查

      • 确认Flink的Doris连接器配置是否正确设置了列分隔符和行分隔符。错误信息中提到的列分隔符是[],这通常是不常见的,通常应该是逗号或制表符。
    7. 字段顺序问题

      • 确保数据源中的字段顺序与Doris表的字段顺序完全一致。

    如果以上检查都没有发现问题,可能需要更深入地调查代码和数据流,或者向Flink社区或Doris的开发者寻求帮助,以确定具体原因。

    2024-05-14 08:32:12
    赞同 展开评论 打赏

大数据领域前沿技术分享与交流,这里不止有技术干货、学习心得、企业实践、社区活动,还有未来。

相关产品

  • 实时计算 Flink版
  • 相关电子书

    更多
    Flink CDC Meetup PPT - 龚中强 立即下载
    Flink CDC Meetup PPT - 王赫 立即下载
    Flink CDC Meetup PPT - 覃立辉 立即下载