报错GENERIC_INTERNAL_ERROR(65536)处理

presto查询apache druid的数据插入到kudu偶尔报错:GENERIC_INTERNAL_ERROR(65536)
java.lang.IllegalArgumentException:Unknow field druid.druid.数据源名称.字段名:varchar
com.google.common.base.Preconditions.checkArgument(Preconditions.java:216)

查看druid日志发现对应报错:
Unknown exception(org.apache.calcite.tools.ValidationException):org.apache.calcite.runtime.CalciteContextException:From line 2,column 8 to line 2,column 12:Column ‘字段名’ not found in any table
另外使用superset获取druid对应数据源的数据预览时也偶尔会报错

问题分析:
1.首先判断应该是druid的问题,同一个操作只是偶尔报错,怀疑是druid broker的问题。
2.通过不同broker查询同一数据源的的列数量的发现结果不一致(SQL:SELECT COUNT(*) columnCount FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NEME=‘数据源名称’),可能是由于滚动重启broker时,historical还未对所有segment提供服务(重启historical后未完成segment load,还在逐步load segment),导致不同时刻通过segment获取到的维度指标等SCHEMA信息有差异。

解决办法:在historical加载完segment后重启broker,保证broker通过segment获取到的维度指标等SCHEMA信息一致。后续重启broker要保证集群中的所有segment都正常对外提供服务。

总结:报错出现的原因是两次获取的SCHEMA信息不一致,不一致可能是由于增加、删除列,或者修改列名、列数据类型导致的。解决SCHEMA信息不一致的问题,即可解决当前报错。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值