美文网首页
解决NameNode配置HA后Hive路径不正确的问题

解决NameNode配置HA后Hive路径不正确的问题

作者: 雨中星辰0 | 来源:发表于2018-12-01 09:00 被阅读0次

    配置了NameNode的HA后,Hive无正常查询数据了,但是其他的组件HDFS , HBase ,Spark都正常的。 Hive查询会出现如下异常

    FAILED: SemanticException Unable to determine if hdfs://bdc240.hexun.com:8020/user/hive/warehouse/test1 is encrypted: java.lang.IllegalArgumentException: Wrong FS: hdfs://bdc240.hexun.com:8020/user/hive/warehouse/test1, expected: hdfs://nameservice1  
    
    

    是Hive元数据的问题,在Hive数据库中有两张表: DBS : Hive数据仓库的总路径 SDS : Hive每张表对应的路径

    数据库中保存了原来的hdfs的路径,修改成HA对应的别名即可

    通常元数据库都采用MySQL使用sql进行字段内容替换非常方便: 相关sql规范:

    update 表名 set 字段名=REPLACE (字段名,'原来的值','要修改的值')  
    

    修改范例:

    update DBS set DB_LOCATION_URI=REPLACE (DB_LOCATION_URI,'bdc240.hexun.com:8020','nameservice1');  
    update SDS set LOCATION=REPLACE (LOCATION,'bdc240.hexun.com:8020','nameservice1');  
    

    如果启动了hiveserver的话,还需要重启hiveserver

    相关文章

      网友评论

          本文标题:解决NameNode配置HA后Hive路径不正确的问题

          本文链接:https://www.haomeiwen.com/subject/badlcqtx.html