当前位置:   article > 正文

hive启动MetaStore报错解决方案_hive.metastore.schema.verification

hive.metastore.schema.verification

安装apache-hive-3.1.1时启动bin/hive --service metastore时出现的错误

第一条错误
在这里插入图片描述

原因: H I V E H O M E / l i b 目 录 下 没 有 找 到 m y s q l − c o n n e c t o r 的 j a r 包 , 因 为 我 配 置 的 源 数 据 是 M y S Q L 数 据 库 , 然 后 把 m y s q l − c o n n e c t o r − j a v a − 5.1.27 − b i n . j a r 下 载 放 到 {HIVE_HOME}/lib目录下没有找到mysql-connector的jar包,因为我配置的源数据是MySQL数据库,然后把mysql-connector-java-5.1.27-bin.jar下载放到 HIVEHOME/libmysqlconnectorjarMySQLmysqlconnectorjava5.1.27bin.jar{HIVE_HOME}/lib目录下再次启动。发现报错如下:
在这里插入图片描述原因:MySQL中的MetaStore数据库中存储的源数据版本和现在用的hive版本不匹配(修改hive-site.xml配置文件中javax.jdo.option.ConnectionURL属性的值,此属性是指定MetaStore连接地址及数据库的,将其设置成MySQL的连接地址及指定数据库就OK)

如果你只有一个hive版本,可以有以下两种解决方案:

1.登陆mysql,修改hive metastore版本:

进行mysql:mysql -uroot -p 123456
use hive; -- 配置文件中javax.jdo.option.ConnectionURL属性值指定的数据库名称
select * from version;
update VERSION set SCHEMA_VERSION='3.1.1' where  VER_ID=1;
  • 1
  • 2
  • 3
  • 4

2.简单粗暴:在hvie-site.xml中关闭版本验证

<property>
	<name>hive.metastore.schema.verification</name>
	<value>false</value>
</property>
  • 1
  • 2
  • 3
  • 4

我按照上面将javax.jdo.option.ConnectionURL的属性值改成另外一个数据库后启动MetaStore发现报错如下(MySQL数据库没有没有):
在这里插入图片描述
解决方案:将下列两个属性设置为false

<property>
 <name>datanucleus.metadata.validate</name>
 <value>false</value>
</property>
<property>
 <name>hive.metastore.schema.verification</name>
 <value>false</value>
</property>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

接下来报错:
在这里插入图片描述
因为在此实验环境中,hive的元数据保存在远程的mysql中,所以该错误意思是:在远程的数据库中没有找到相应的数据对象。

解决办法:将下列属性设置为true

<property>
	<name>datanucleus.schema.autoCreateAll</name>
	<value>true</value>
</property>
  • 1
  • 2
  • 3
  • 4

这个属性的含义是:当元数据库中必要的数据对象不存在是,会自动创建。、

在xml配置文件中,在标签之间不要有空格!!!因为读取xml文件时是按标签读取的。

原文https://blog.csdn.net/lz6363/article/details/85019891

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/429559
推荐阅读
相关标签
  

闽ICP备14008679号