Hive 中 metastore(元数据存储)的三种方式:
        a)内嵌 Derby 方式
        b)Local 方式 
        c)Remote 方式 
 

第一种方式:本地 mysql

注: 这种存储方式需要在本地运行一个 mysql 服务器,并作如下配置,使用 mysql 的方 式,需要将 mysql 的 jar 包拷贝到$HIVE_HOME/lib 目录下
 

1.  安装mysql, 修改权限

yum  install  mysqld-server
chkconfig  mysqld  on  设置开机启动
service  mysqld  start  启动mysql
 
进入mysql
mysql
use  mysql;
show  tables;
desc;
select  host,  user,  password  from   user;
 
修改mysql权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123' WITH GRANT OPTION; 
delete  from  user;
flush  privileges;  刷新权限
 
quit
mysql
mysql  -u  root  -p
此时需要输入密码,进入mysql, 如果能够进入,则mysql修改成功
 

2. 同一台主机上安装 hive

上传hive压缩包,并解压到home目录下
tar  zxvf  apache-hive-1.2.1-bin.tar.gz  -C  /home
 
配置hive环境变量
vi  /etc/profile  
 

source  /etc/profile
 
修改hive的配置文件

 

vi  hive-site.xml

 

hive   
发现报如下错误,只需要拷贝mysql的jar包到hive的lib下即可

 

hive中的高版本替换hadoop中的低版本
hive中的高版本
 

hadoop中的jline为低版本-->替换为高版本

进入hive中的lib目录,进行copy到hadoop中的lib下
cp    jline-2.12.jar     /root/hadoop-2.5.1/share/hadoop/yarn/lib
 
然后   hive   就成功进入了!!!

测试hive

 

注:使用 derby 存储方式时,运行 hive会在当前目录生成一个 derby 文件和一个metastore_db 目录。这种存储方式的弊端是在同一个目录下同时只能有一个 hive 客户端能使用数据库, 否则会提示如下错误 [html] view plaincopyprint? hive> show tables;   FAILED: Error in metadata: javax.jdo.JDOFatalDataStoreException: Failed to start database 'metast ore_db', see the next exception for details.   NestedThrowables:   java.sql.SQLException: Failed to start database 'metastore_db', see the next exception for details.   FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask   hive> show tables; FAILED: Error in metadata: javax.jdo.JDOFatalDataStoreException: Failed to start database 'metastore_db', see the next exception for details. NestedThrowables: java.sql.SQLException: Failed to start database 'metastore_db', see the next exception for details. FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask 
 

第二种方式:远端mysql--remote分开       亲测安装

假定node1为客户端,node2为服务端
node1和node2上传hive压缩包,并解压到home路径下,配置hive环境变量
 
服务端node2:服务端需要mysql jar包
拷贝mysql-connecor-java.jar到hive的lib下

cd  conf
mv  hive-default.template.xml  hive-site.xml
vi  hive-site.xml

 

  1. <configuration>
  2.  
  3. <property>
  4. <name>hive.metastore.warehouse.dir</name>
  5. <value>/opt/hive/warehouse</value>
  6. </property>
  7. <property>
  8. <name>javax.jdo.option.ConnectionURL</name>
  9. <value>jdbc:mysql://192.168.1.33:3306/hive?createDatabaseIfNotExist=true</value>
  10. <description>JDBC connect string for a JDBC metastore</description>
  11. </property>
  12.  
  13. <property>
  14. <name>javax.jdo.option.ConnectionDriverName</name>
  15. <value>com.mysql.jdbc.Driver</value>
  16. <description>Driver class name for a JDBC metastore</description>
  17. </property>
  18.  
  19. <property>
  20. <name>javax.jdo.option.ConnectionUserName</name>
  21. <value>root</value>
  22. <description>username to use against metastore database</description>
  23. </property>
  24.  
  25. <property>
  26. <name>javax.jdo.option.ConnectionPassword</name>
  27. <value>123456</value>
  28. <description>password to use against metastore database</description>
  29. </property>
  30. </configuration>

  

客户端node1:
首先替换hadoop中jline的版本为hive中的高版本,步骤参考第一种方式
cd  conf  
mv  hive-default.template.xml  hive-site.xml
vi  hive-site.xml

 

  1. <configuration>
  2. <property>
  3. <name>hive.metastore.warehouse.dir</name>
  4. <value>/opt/hive/warehouse</value>
  5. </property>
  6. <property>
  7. <name>hive.metastore.local</name>
  8. <value>false</value>
  9. </property>
  10. <property>
  11. <name>hive.metastore.uris</name>
  12. <value>thrift://node1:9083</value>
  13. </property>
  14. </configuration>

  

客户端服务端修改hive-env.sh配置其中的$hadoop_home

测试hive:
node2:  
   hive  --service  metastore
node1:  
   hive
    create table tbl (id int, name string);
    insert into tbl values(1, 'zhangsan');
    select * from tbl;
 

第三种方式:本地derby

这种方式是最简单的存储方式,只需要在 hive-site.xml 做如下配置便可
 <?xml version="1.0"?>   
 <?xml-stylesheet type="text/xsl" href="configuration.xsl"?>      
 <configuration>      
     <property>     
           <name>javax.jdo.option.ConnectionURL</name>    
           <value>jdbc:derby:;databaseName=metastore_db;create=true</value>  
     </property>      
     <property>    
            <name>javax.jdo.option.ConnectionDriverName</name> 
            <value>org.apache.derby.jdbc.EmbeddedDriver</value>   
     </property>    
     <property>  
             <name>hive.metastore.local</name>    
             <value>true</value>  
     </property>     
     <property>    
             <name>hive.metastore.warehouse.dir</name>   
             <value>/user/hive/warehouse</value>
      </property>        
</configuration>   
 
注:使用 derby 存储方式时,运行 hive会在当前目录生成一个 derby 文件和一个metastore_db 目录。这种存储方式的弊端是在同一个目录下同时只能有一个 hive 客户端能使用数据库, 否则会提示如下错误 [html] view plaincopyprint? hive> show tables;   FAILED: Error in metadata: javax.jdo.JDOFatalDataStoreException: Failed to start database 'metast ore_db', see the next exception for details.   NestedThrowables:   java.sql.SQLException: Failed to start database 'metastore_db', see the next exception for details.   FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask   hive> show tables; FAILED: Error in metadata: javax.jdo.JDOFatalDataStoreException: Failed to start database 'metastore_db', see the next exception for details. NestedThrowables: java.sql.SQLException: Failed to start database 'metastore_db', see the next exception for details. FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask 

hive三种方式区别和搭建的更多相关文章

  1. Hadoop Hive概念学习系列之hive三种方式区别和搭建、HiveServer2环境搭建、HWI环境搭建和beeline环境搭建(五)

     说在前面的话 以下三种情况,最好是在3台集群里做,比如,master.slave1.slave2的master和slave1都安装了hive,将master作为服务端,将slave1作为服务端. 以 ...

  2. vue路由传参的三种方式区别(params,query)

    最近在做一个项目涉及到列表到详情页的参数的传递,网上搜索一下路由传参,结合自己的写法找到一种适合自己的,不过也对三种写法都有了了解,在此记录一下 <ul class="table_in ...

  3. JS对url进行编码和解码(三种方式区别)

    Javascript语言用于编码的函数,一共有三个,最古老的一个就是escape().虽然这个函数现在已经不提倡使用了,但是由于历史原因,很多地方还在使用它,所以有必要先从它讲起. escape 和 ...

  4. java 复用类的三种方式区别 组合,继承,代理的区别

    1. 组合 : 只需在新类中产生现有类的对象 .(is - a 有一个) 新类是由现有类的对象组成. (引用初始化与作用域?) 2. 继承 : 按照现有类的类型来创造新类. (has - a 有一个) ...

  5. javascript函数命名的三种方式及区别

    1, function fn(val1,val2) { alert(val1+val2); } fn(1,2); 2, var fn=function() { alert(val1+val2); } ...

  6. React创建组件的三种方式及其区别

    内容转载于http://www.cnblogs.com/wonyun/p/5930333.html React推出后,出于不同的原因先后出现三种定义react组件的方式,殊途同归; 具体的三种方式: ...

  7. 301-React Ext-React创建组件的三种方式及其区别

    一.概述 React推出后,出于不同的原因先后出现三种定义react组件的方式,殊途同归:具体的三种方式: 函数式定义的无状态组件 es5原生方式React.createClass定义的组件 es6形 ...

  8. Hive三种不同的数据导出的方式

    转自:http://blog.chinaunix.net/uid-27177626-id-4653808.html Hive三种不同的数据导出的方式,根据导出的地方不一样,将这些方法分为三类:(1)导 ...

  9. php集成开发环境搭建三种方式

    三种方式都是一键搭建php开发环境 三种方式前提都是在linux下 wamp和phpstudy就不再用了 首先打造linux开发环境,通过vagrant+vbox实现本地文件同步到虚拟机上进行同步开发 ...

随机推荐

  1. 小a的轰炸游戏(差分,前缀和)

    题目传送门 题意: 给出一个n*m的矩形,然后有两个操作. 1操作,对一个给出的菱形,对菱形范围内的东西进行+1. 2操作,对一个上半菱形的区域,进行+1操作. 最后求矩形内各个数的异或和. 思路: ...

  2. 字符串hash 模板

    typedef long long ll; typedef unsigned long long ull; #define maxn 1005 struct My_Hash { ull ; ull p ...

  3. C语言--一维数组,字符数组

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/zuoyou1314/article/details/30799519 watermark/2/tex ...

  4. asp.net Excel导入和导出

    1.Excel数据导入到数据库中: //该方法实现从Excel中导出数据到DataSet中,其中filepath为Excel文件的绝对路径,sheetname为表示那个Excel表:        p ...

  5. oracle比较两个查询结果的差异

    可以使用minus select * from A minus select * from B; select * from B minus select * from A;

  6. 隐藏系统和 Apache 的版本信息

    方法一: ※首先修改源文件,再进行 make && make install 编译安装 编辑源文件/usr/local/apache2/include/ap_release.h 文件 ...

  7. 【转】uboot中的mmc命令

    转自:https://www.cnblogs.com/yxwkf/p/3855383.html 1:mmcinfo 输入: mmcinfo 显示结果:Manufacturer ID: 45OEM: 1 ...

  8. 2019 蓝桥杯国赛 B 组模拟赛 E 蒜头图 (并查集判环)

    思路: 我们看条件,发现满足条件的子图无非就是一些环构成的图, 因为只有形成环,才满足边的两个点都在子图中,并且子图中节点的度是大于0的偶数. 那么如果当前有k个环,我们可以选2^k-1个子图,为什么 ...

  9. canvas在图片上生成文字

    newImage(text) {                 // 生成图片                 var imageBox = document.getElementById(&quo ...

  10. awk基础学习

    2019-12-20 需要巧记,很多格式,学习难度:grep.sed.awk awk知识概述 1三剑客awk命令介绍2三剑客awk命令执行原理语法结构3三剑客awk命令实操练习查询替换信息排除(取反) ...