因异常 java.io.IOException:java.lang.RuntimeException: 查询 hive orc 表时出现严重问题而失败

问题描述

我使用以下查询创建了一个 ORC 格式的 hive 表,并且我能够在集群 1 中查询相同的表。 现在我已经使用 distcp 将底层 ORC 文件传输到不同的集群(集群 2),并且我在集群 2 中创建了相同的表结构。 当我运行 msck repair table 时,它​​能够加载分区,但是当我查询它的失败并出现严重问题时。

用于在集群 1 的 distcp orc 文件之后创建集群 2 中的表的查询

 CREATE TABLE `test_db_cluster_2.test_audit`(
  `sno` Int,`source_timestamp` string,`commit_timestamp` string,`ing_timestamp` string,`count` int,`merge_timestamp` string)
  partitioned by (tableName String)
ROW FORMAT SERDE
  'org.apache.hadoop.hive.ql.io.orc.OrcSerde'
STORED AS INPUTFORMAT
  'org.apache.hadoop.hive.ql.io.orc.OrcInputFormat'
OUTPUTFORMAT
  'org.apache.hadoop.hive.ql.io.orc.OrcOutputFormat';
  LOCATION
  'hdfs://OMEGAPRD/user/svc-omg_1clrven_pld/cdl/test_audit'; 

已执行 msck 修复:(成功)

hive> msck repair table 1clrven_prdstg_tbls.test_audit;
OK
Partitions not in metastore:    test_audit:tablename=fin_s4hana_prd_tbls.ska1
Repair: Added partition to metastore 1clrven_prdstg_tbls.test_audit:tablename=fin_s4hana_prd_tbls.ska1
Time taken: 0.962 seconds,Fetched: 2 row(s) 

当我查询表时,它失败并出现以下错误

hive> select * from 1clrven_prdstg_tbls.test_audit;
OK
Failed with exception java.io.IOException:java.lang.RuntimeException: serIoUs problem

你能帮我解释一下为什么会这样吗? 两者都有相同的兽人文件。但是 cluster-1 我们在创建表后使用 insert into 插入数据,在 cluster-2 中我们传输文件并在其上创建表格。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)