时间:2021-07-01 10:21:17 帮助过:31人阅读
元数据信息不存在HDFS,而是存在关系型数据库里,hive默认用的是derby数据库来存储。即hive工作时,除了要依赖Hadoop,还要依赖关系型数据库。
注意:虽然我们能通过HDFS查看到hive有哪些数据库,有哪些表,以及表里的数据,但是,这不是元数据信息。HDFS最主要的是存储hive的数据信息。
之前遇到的问题:当退出后,切换到不同的目录来进入hive,发现库和表没有了,是因为,第一次从bin目录进入hive,会在bin目录下创建一个metastore.db目录,在这个目录下,创建一个derby.log文件来存储
元数据信息。这个元数据信息是基于bin目录来创建的。而切换到其他目录进入hive时,查询时不是基于bin目录来查询的,所有查不到元数据信息,导致查不到。这个问题是derby数据库本身的问题,所以,我们不能用derby数据库,此外,用derby数据库,也不支持并发,比如一个人在操作hive,如果此时有其他人想用hive,用不了。所以我们选择用mysql数据库。目前hive支持derby和mysql两种数据库。
Linux下mysql的安装过程:Linux下的MySQL安装
执行:hadoop fs -rmr /user/hive(需要启动hadoop)
我这里采用rz命令来上传:mysql-connector-java-5.1.38-bin.jar
<configuration> <property> <name>javax.jdo.option.ConnectionURL</name> <value>jdbc:mysql://hadoopalone:3306/hive?createDatabaseIfNotExist=true</value> //mysql的url </property> <property> <name>javax.jdo.option.ConnectionDriverName</name> <value>com.mysql.jdbc.Driver</value> </property> <property> <name>javax.jdo.option.ConnectionUserName</name> //mysql的用户名 <value>root</value> </property> <property> <name>javax.jdo.option.ConnectionPassword</name> //mysql的密码 <value>root</value> </property> </configuration>
如图所示,添加如下配置
如果出现:
Access denied for user ‘root‘@‘hadoop01‘ (using password: YES)这个错误,指的是当前用户操作mysql数据库的权限不够。
执行:grant all privileges on *.* to ‘root‘@‘hadoopalone‘ identified by ‘root‘ with grant option;
grant all on *.* to ‘root‘@‘%‘ identified by ‘root‘;
然后执行:flush privileges;(注意分号)
如果不事先在mysql里创建hive数据库,在进入hive时,mysql会自动创建hive数据库。但是注意,因为我们之前配置过mysql的字符集为utf-8,所以这个自动创建的hive数据库的字符集是utf-8的。
但是hive要求存储元数据的字符集必须是iso8859-1。如果不是的话,hive会在创建表的时候报错(先是卡一会,然后报错)。
进入mysql执行:create database hive character set latin1;
至此,Hive配置mysql大功告成!如果有什么问题,大家一起留言讨论。
Hive的mysql安装配置
标签:创建表 post 问题 oop 一起 inux mysql安装 mysql配置 nav