hive概念、安装和配置、常见异常

一、概念

Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供类SQL查询功能。
本质是将SQL转换为MapReduce程序
  1. hive的元数据
    - Hive将元数据储存在数据库中(metastore),支持mysql,derby,oracle等数据库。
    - Hive中的元数据包括表的名字,表的列和分区及其属性,表的属性(是否为外部表等),表的数据所在目录等

  2. HQL的执行过程
    解释器、编译器、优化器完成HQL查询语句从词法分析、语法分析、编译、优化以及查询计划(PLAN)的生成。生成的查询计划储存在HDFS中,并在随后又MapReduce调用执行

  3. Hive的结构体系


二、安装、配置
 
     - Hive安装模式分为嵌入模式、本地模式、远程模式三种模式
     - 嵌入模式:Hive将元信息存储到derby数据库中。它只能创建一个连接,同一时间只能一个人操作Hive
     - 本地模式:Hive将元信息储存在MySQL数据库中。Mysql数据库与Hive运行在同一台物理机器上,支持多个连接,多用于开发和测试
     - 远程模式:Hive将元信息储存在Mysql数据库中。Mysql数据库与Hive运行在不同的物理机器上,多用于生产环境

  1. 准备
    apache-hive-1.2.1-bin.tar.gz安装包,下载地址:http://apache.fayea.com/hive/hive-1.2.1/
    将hive安装包上传至linux的root目录下

  2. 安装
    解压安装,tar zxvf apache-hive-1.2.1.tar.gz
    建立软链接,ln -sf /root/apache-hive-1.2.1-bin /home/hive

  3. 配置
    cd /home/hive/conf目录
    cp hive-default.xml.template hive-site.xml
    配置环境变量
    vim /etc/profile
    [java]  view plain  copy
    1. export HIVE_INSTALL=/home/hive  
    2. export PATH=$PATH:$HIVE_INSTALL/bin  
    source /etc/profile

  4. 启动hive,成功!


三、安装关系型数据库MySQL
  1. 通过查看hive/conf/hive-site.xml,hive自带的关系型数据库是derby,这种数据库不稳定
    [java]  view plain  copy
    1. <property>  
    2.     <name>javax.jdo.option.ConnectionURL</name>  
    3.     <value>jdbc:derby:;databaseName=metastore_db;create=true</value>  
    4.     <description>JDBC connect string for a JDBC metastore</description>  
    5.   </property>  
四、常见异常
  1. [java]  view plain  copy
    1. [root@node1 bin]# hive  
    2.   
    3. Logging initialized using configuration in jar:file:/root/apache-hive-1.2.1-bin/lib/hive-common-1.2.1.jar!/hive-log4j.properties  
    4. Exception in thread "main" java.lang.RuntimeException: java.lang.IllegalArgumentException: java.net.URISyntaxException: Relative path in absolute URI: ${system:java.io.tmpdir%7D/$%7Bsystem:user.name%7D  
    5.     at org.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:522)  
    6.     at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:677)  
    7.     at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:621)  
    8.     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  
    9.     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)  
    10.     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)  
    11.     at java.lang.reflect.Method.invoke(Method.java:606)  
    12.     at org.apache.hadoop.util.RunJar.main(RunJar.java:212)  
    13. Caused by: java.lang.IllegalArgumentException: java.net.URISyntaxException: Relative path in absolute URI: ${system:java.io.tmpdir%7D/$%7Bsystem:user.name%7D  
    14.     at org.apache.hadoop.fs.Path.initialize(Path.java:206)  
    15.     at org.apache.hadoop.fs.Path.<init>(Path.java:172)  
    16.     at org.apache.hadoop.hive.ql.session.SessionState.createSessionDirs(SessionState.java:563)  
    17.     at org.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:508)  
    18.     ... 7 more  
    19. Caused by: java.net.URISyntaxException: Relative path in absolute URI: ${system:java.io.tmpdir%7D/$%7Bsystem:user.name%7D  
    20.     at java.net.URI.checkPath(URI.java:1804)  
    21.     at java.net.URI.<init>(URI.java:752)  
    22.     at org.apache.hadoop.fs.Path.initialize(Path.java:203)  
    23.     ... 10 more  

    解决办法:
    vim conf/hive-site.xml,增加下面两项配置内容
    [java]  view plain  copy
    1. <property>  
    2.         <name>system:java.io.tmpdir</name>  
    3.         <value>/opt/hive/tmpdir</value>  
    4. </property>  
    5.   
    6. <property>  
    7.         <name>system:user.name</name>  
    8.         <value>username</value>  
    9. </property>  


  2. 异常二
    [java]  view plain  copy
    1. [root@node1 lib]# hive  
    2.   
    3. Logging initialized using configuration in jar:file:/root/apache-hive-1.2.1-bin/lib/hive-common-1.2.1.jar!/hive-log4j.properties  
    4. [ERROR] Terminal initialization failed; falling back to unsupported  
    5. java.lang.IncompatibleClassChangeError: Found class jline.Terminal, but interface was expected  
    6.     at jline.TerminalFactory.create(TerminalFactory.java:101)  
    7.     at jline.TerminalFactory.get(TerminalFactory.java:158)  
    8.     at jline.console.ConsoleReader.<init>(ConsoleReader.java:229)  
    9.     at jline.console.ConsoleReader.<init>(ConsoleReader.java:221)  
    10.     at jline.console.ConsoleReader.<init>(ConsoleReader.java:209)  
    11.     at org.apache.hadoop.hive.cli.CliDriver.setupConsoleReader(CliDriver.java:787)  
    12.     at org.apache.hadoop.hive.cli.CliDriver.executeDriver(CliDriver.java:721)  
    13.     at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:681)  
    14.     at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:621)  
    15.     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  
    16.     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)  
    17.     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)  
    18.     at java.lang.reflect.Method.invoke(Method.java:606)  
    19.     at org.apache.hadoop.util.RunJar.main(RunJar.java:212)  
    20.   
    21. Exception in thread "main" java.lang.IncompatibleClassChangeError: Found class jline.Terminal, but interface was expected  
    22.     at jline.console.ConsoleReader.<init>(ConsoleReader.java:230)  
    23.     at jline.console.ConsoleReader.<init>(ConsoleReader.java:221)  
    24.     at jline.console.ConsoleReader.<init>(ConsoleReader.java:209)  
    25.     at org.apache.hadoop.hive.cli.CliDriver.setupConsoleReader(CliDriver.java:787)  
    26.     at org.apache.hadoop.hive.cli.CliDriver.executeDriver(CliDriver.java:721)  
    27.     at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:681)  
    28.     at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:621)  
    29.     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  
    30.     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)  
    31.     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)  
    32.     at java.lang.reflect.Method.invoke(Method.java:606)  
    33.     at org.apache.hadoop.util.RunJar.main(RunJar.java:212)  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值