赞
踩
安装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/lib目录下没有找到mysql−connector的jar包,因为我配置的源数据是MySQL数据库,然后把mysql−connector−java−5.1.27−bin.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;
2.简单粗暴:在hvie-site.xml中关闭版本验证
<property>
<name>hive.metastore.schema.verification</name>
<value>false</value>
</property>
我按照上面将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>
接下来报错:
因为在此实验环境中,hive的元数据保存在远程的mysql中,所以该错误意思是:在远程的数据库中没有找到相应的数据对象。
解决办法:将下列属性设置为true
<property>
<name>datanucleus.schema.autoCreateAll</name>
<value>true</value>
</property>
这个属性的含义是:当元数据库中必要的数据对象不存在是,会自动创建。、
在xml配置文件中,在标签之间不要有空格!!!因为读取xml文件时是按标签读取的。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。