[TOC]
# hive架構圖

## 基本組成
* 用戶接口:包括 CLI、JDBC/ODBC、WebGUI。
* 元數據存儲:通常是存儲在關系數據庫如 mysql , derby中。
* 解釋器、編譯器、優化器、執行器。
## 各組件的基本功能
* 用戶接口主要由三個:CLI、JDBC/ODBC和WebGUI。其中,CLI為shell命令行;JDBC/ODBC是Hive的JAVA實現,與傳統數據庫JDBC類似;WebGUI是通過瀏覽器訪問Hive。
* 元數據存儲:Hive 將元數據存儲在數據庫中。Hive 中的元數據包括表的名字,表的列和分區及其屬性,表的屬性(是否為外部表等),表的數據所在目錄等。
* 解釋器、編譯器、優化器完成 HQL 查詢語句從詞法分析、語法分析、編譯、優化以及查詢計劃的生成。生成的查詢計劃存儲在 HDFS 中,并在隨后有 MapReduce 調用執行。
## Hive與Hadoop的關系
Hive利用HDFS存儲數據,利用MapReduce查詢分析數據

## Hive與傳統數據庫對比
hive用于海量數據的離線數據分析

總結:hive具有關系型數據庫的查詢分析功能,但應用場景完全不同,hive只適合用來做批量數據統計分析,數據量大、對應的延遲較高!
## Hive的數據存儲
1. Hive中所有的數據都存儲在 HDFS 中,沒有專門的數據存儲格式(可支持Text,SequenceFile,ParquetFile,RCFILE等)
SequenceFile是hadoop中的一種文件格式:
文件內容是以序列化的kv對象來組織的
2. 只需要在創建表的時候告訴 Hive 數據中的列分隔符和行分隔符,Hive 就可以解析數據
3. Hive 中包含以下數據模型:DB、Table,External Table,Partition,Bucket。
* db:在hdfs中表現為`${hive.metastore.warehouse.dir}`目錄下一個文件夾
* table:在hdfs中表現所屬db目錄下一個文件夾
* external table:與table類似,不過其數據存放位置可以在任意指定路徑
* partition:在hdfs中表現為table目錄下的子目錄
* bucket:在hdfs中表現為同一個表目錄下根據hash散列之后的多個文件
# 安裝
## derby版:
1. 解壓hive
2. 解決一下版本不兼容問題:替換 `hadoop/share/hadoop/yarn/lib`中的老版本jline 為hive的lib中的jline-2.12.jar

使用方式
Hive交互shell
~~~
bin/hive
~~~
一些交互命令
~~~
hive> create database db1;
OK
Time taken: 0.258 seconds
hive> create database db2;
OK
Time taken: 0.063 seconds
hive> show databases;
OK
db1
db2
default
Time taken: 0.008 seconds, Fetched: 3 row(s)
hive>
~~~
這邊創建了一些庫,這些庫在哪里?
在你執行啟動hive命令下面有個`metastore_db`這個文件夾
不同的用戶在不同的目錄下啟動,都會在不同的目錄下創建`metastore_db`這個文件夾
這就是把元數據放在derby中
這樣就不便于我們的管理
缺點:多個地方安裝hive后,每一個hive是擁有一套自己的元數據,大家的庫、表就不統一;
## 元數據庫mysql版:
1. 解壓
2. 修改配置文件
3. 加載mysql數據驅動包
在hive的conf文件夾下
~~~
vim hive-site.xml
~~~
配置數據庫信息
~~~
<configuration>
<property>
<name>javax.jdo.option.ConnectionURL</name>
<value>jdbc:mysql://192.168.33.10:3306/hive?createDatabaseIfNotExist=true</value>
<description>JDBC connect string for a JDBC metastore</description>
</property>
<property>
<name>javax.jdo.option.ConnectionDriverName</name>
<value>com.mysql.jdbc.Driver</value>
<description>Driver class name for a JDBC metastore</description>
</property>
<property>
<name>javax.jdo.option.ConnectionUserName</name>
<value>root</value>
<description>username to use against metastore database</description>
</property>
<property>
<name>javax.jdo.option.ConnectionPassword</name>
<value>root</value>
<description>password to use against metastore database</description>
</property>
</configuration>
~~~
然后配置環境變量
~~~
mv hive-env.sh.template hive-env.sh
vim hive-env.sh
~~~
把里面的`HADOOP_HOME`配置為你自己的hadoop路徑,然后把注釋放開
然后把之前derby版的`metastore_db`這個文件夾,刪除了
在lib目錄下上傳個mysql驅動的jar包
然后就可以操作了
試著插入些庫,表還有數據
然后插入成功就看下網頁版的

這邊會看到創建的庫
## Hive JDBC服務

hive也可以啟動為一個服務器,來對外提供
啟動方式,(假如是在h01上):
啟動為前臺(啟動成功會占用100000端口):
~~~
bin/hiveserver2
~~~
啟動為后臺:
~~~
nohup bin/hiveserver2 1>/var/log/hiveserver.log 2>/var/log/hiveserver.err &
~~~
啟動成功后,可以在別的節點上用beeline去連接
* 方式(1)
hive/bin/beeline 回車,進入beeline的命令界面
輸入命令連接hiveserver2
~~~
[root@master bin]# beeline
Beeline version 1.2.1 by Apache Hive
beeline> !connect jdbc:hive2://127.0.0.1:10000
Connecting to jdbc:hive2://127.0.0.1:10000
Enter username for jdbc:hive2://127.0.0.1:10000: root
Enter password for jdbc:hive2://127.0.0.1:10000:
Connected to: Apache Hive (version 1.2.1)
Driver: Hive JDBC (version 1.2.1)
Transaction isolation: TRANSACTION_REPEATABLE_READ
0: jdbc:hive2://127.0.0.1:10000>
~~~
用戶名是root,密碼直接回車
然后那邊hiveserver2是顯示ok
上面ip端口是127.0.0.1:10000
* 方式(2)
或者啟動就連接:
~~~
bin/beeline -u jdbc:hive2://127.0.0.1:10000 -n root
~~~
接下來就可以做正常sql查詢了
- linux
- 常用命令
- 高級文本命令
- 面試題
- redis
- String
- list
- hash
- set
- sortedSet
- 案例-推薦
- java高級特性
- 多線程
- 實現線程的三種方式
- 同步關鍵詞
- 讀寫鎖
- 鎖的相關概念
- 多線程的join
- 有三個線程T1 T2 T3,保證順序執行
- java五種線程池
- 守護線程與普通線程
- ThreadLocal
- BlockingQueue消息隊列
- JMS
- 反射
- volatile
- jvm
- IO
- nio
- netty
- netty簡介
- 案例一發送字符串
- 案例二發送對象
- 輕量級RPC開發
- 簡介
- spring(IOC/AOP)
- spring初始化順序
- 通過ApplicationContextAware加載Spring上下文
- InitializingBean的作用
- 結論
- 自定義注解
- zk在框架中的應用
- hadoop
- 簡介
- hadoop集群搭建
- hadoop單機安裝
- HDFS簡介
- hdfs基本操作
- hdfs環境搭建
- 常見問題匯總
- hdfs客戶端操作
- mapreduce工作機制
- 案列-單詞統計
- 局部聚合Combiner
- 案列-流量統計(分區,排序,比較)
- 案列-倒排索引
- 案例-共同好友
- 案列-join算法實現
- 案例-求topN(分組)
- 自定義inputFormat
- 自定義outputFormat
- 框架運算全流程
- mapreduce的優化方案
- HA機制
- Hive
- 安裝
- DDL操作
- 創建表
- 修改表
- DML操作
- Load
- insert
- select
- join操作
- 嚴格模式
- 數據類型
- shell參數
- 函數
- 內置運算符
- 內置函數
- 自定義函數
- Transform實現
- 特殊分割符處理
- 案例
- 級聯求和accumulate
- flume
- 簡介
- 安裝
- 常用的組件
- 攔截器
- 案例
- 采集目錄到HDFS
- 采集文件到HDFS
- 多個agent串聯
- 日志采集和匯總
- 自定義攔截器
- 高可用配置
- 使用注意
- sqoop
- 安裝
- 數據導入
- 導入數據到HDFS
- 導入關系表到HIVE
- 導入表數據子集
- 增量導入
- 數據導出
- 作業
- 原理
- azkaban
- 簡介
- 安裝
- 案例
- 簡介
- command類型單一job
- command類型多job工作流flow
- HDFS操作任務
- mapreduce任務
- hive腳本任務
- hbase
- 簡介
- 安裝
- 命令行
- 基本CURD
- 過濾器查詢
- 系統架構
- 物理存儲
- 尋址機制
- 讀寫過程
- Region管理
- master工作機制
- 建表高級屬性
- 與mapreduce結合
- 協處理器
- 點擊流平臺開發
- 簡介
- storm
- 簡介
- 安裝
- 集群啟動及任務過程分析
- 單詞統計
- 并行度
- ACK容錯機制
- ACK簡介