配置Hive元数据存储到MySQL


文章目录

配置Hive元数据存储到MySQL

背景介绍

在安装完Hive之后,需要将Hive的元数据写入到MySQL的metastore数据库。

如果说MySQL中缺乏了关于Hive的相关配置,Hive是无法正常启动和运行的。

如果说MySQL进行重装,则需要对Hive服务进行重新的配置。

配置步骤
1) 在MySQL中新建 Hive 元数据库
bash 复制代码
#登录MySQL
[atguigu@hadoop102 software]$ mysql -uroot -p123456

#创建Hive元数据库
mysql> create database metastore;
mysql> quit;
2) 将MySQL的JDBC驱动拷贝到Hive的lib目录下
bash 复制代码
cp /opt/download/mysql-connector-j-8.0.33.jar lib/
3) 更新guava包和hadoop一致
bash 复制代码
ls lib/|grep guava
# guava-19.0.jar
rm -f lib/guava-19.0.jar
find /opt/software/hadoop313/ -name guava*
#/opt/software/hadoop313/share/hadoop/common/lib/guava-27.0-jre.jar
#/opt/software/hadoop313/share/hadoop/hdfs/lib/guava-27.0-jre.jar
cp /opt/software/hadoop313/share/hadoop/hdfs/lib/guava-27.0-jre.jar lib/
4) 在$HIVE_HOME/conf目录下新建hive-site.xml文件
bash 复制代码
[atguigu@hadoop102 software]$ vim $HIVE_HOME/conf/hive-site.xml
添加如下内容:
<?xml version="1.0"?>
<?xml-stylesheet type="text/xsl" href="configuration.xsl"?>

<configuration>
    <!-- jdbc连接的URL -->
     <property>
        <name>javax.jdo.option.ConnectionURL</name>mysql
        <value>jdbc:mysql://localhost:3306/hive312?createDatabaseIfNotExist=true</value>
	</property>
    
    <!-- jdbc连接的Driver-->
    <property>
        <name>javax.jdo.option.ConnectionDriverName</name>
        <value>com.mysql.cj.jdbc.Driver</value>
    </property>
    
	<!-- jdbc连接的username-->
    <property>
        <name>javax.jdo.option.ConnectionUserName</name>
        <value>root</value>
    </property>

    <!-- jdbc连接的password -->
    <property>
        <name>javax.jdo.option.ConnectionPassword</name>
        <value>123456</value>
    </property>

    <!-- Hive默认在HDFS的工作目录 -->
    <property>
        <name>hive.metastore.warehouse.dir</name>
        <value>/hive312/warehouse</value>
    </property>
</configuration>
5) 初始化Hive元数据库(修改为采用MySQL存储元数据)

在初始化之前,需要先到MySQL数据库下查看数据库列表中是否存在hive312数据库,如果存在先删掉,否则会导致元数据库的创建过程失败。

bash 复制代码
schematool -dbType mysql -initSchema -verbose
6) 验证是否成功配置
bash 复制代码
#首先启动元数据服务
nohup hive --service metastore 1>/dev/null 2>&1 &

#1、方法一 hive客户端
hive
#2、方法二 基于metastore和hiveserver2的beeline
#启动hiveserver2服务
nohup hive --service hiveserver2 1>/dev/null 2>&1 &
beeline -u jdbc:hive2://single01:10000
相关推荐
骑士雄师30 分钟前
使用 IntelliJ IDEA 结合 DBeaver 连接 MySQL 数据库并实现数据增删查改的详细步骤:
数据库·mysql·intellij-idea
b78gb2 小时前
电商秒杀系统设计 Java+MySQL实现高并发库存管理与订单处理
java·开发语言·mysql
奥尔特星云大使3 小时前
CentOS 7 安装 MySQL 8
mysql·centos·mysql 8
lang201509283 小时前
MySQL FIPS模式:安全合规全解析
mysql
一只叫煤球的猫5 小时前
建了索引还是慢?索引失效原因有哪些?这10个坑你踩了几个
后端·mysql·性能优化
yumgpkpm8 小时前
华为鲲鹏 Aarch64 环境下多 Oracle 、mysql数据库汇聚到Cloudera CDP7.3操作指南
大数据·数据库·mysql·华为·oracle·kafka·cloudera
程序员云帆哥9 小时前
MySQL JDBC Driver URL参数配置规范
数据库·mysql·jdbc
三三木木七11 小时前
mysql拒绝连接
数据库·mysql
唐古乌梁海11 小时前
【mysql】InnoDB的聚簇索引和非聚簇索引工作原理
数据库·mysql
꒰ঌ 安卓开发໒꒱11 小时前
Mysql 坏表修复
android·mysql·adb