《HIVE安装使用说明.doc》由会员分享,可在线阅读,更多相关《HIVE安装使用说明.doc(16页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、如有侵权,请联系网站删除,仅供学习与交流HIVE安装使用说明【精品文档】第 16 页HIVE安装使用说明一、 Hive简介1.1. Hive是什么Hadoop作为分布式运算的基础架构设施,统计分析需要采用MapReduce编写程序后,放到Hadoop集群中进行统计分析计算,使用起来较为不便,Hive产品采用类似SQL的语句快速实现简单的MapReduce统计,很大程度降低了Hadoop的学习使用成本。Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供基础的SQL查询功能,可以将SQL语句转换为MapReduce任务运行,而不必开发专门的MapRedu
2、ce应用,十分适合数据仓库的统计分析。1.2. 部署架构Hive中的Driver为核心驱动部分,包括SQL语句的解释、编译为MapReduce任务,并进行优化、执行。Hive用户访问包括4种运行和访问方式,一是CLI客户端;二是HiveServer2和Beeline方式;三是HCatalog/WebHCat方式;四是HWI方式。其中CLI、Beeline均为控制台命令行操作模式,区别在于CLI只能操作本地Hive服务,而Beeline可以通过JDBC连接远程服务。HiveServer2为采用Thrift提供的远程调用接口,并提供标准的JDBC连接访问方式。HCatalog是Hadoop的元数据
3、和数据表的管理系统,WebHCat则提供一条Restful的HCatalog远程访问接口,HCatalog的使用目前资料很少,尚未充分了解。HWI是Hive Web Interface的简称,可以理解为CLI的WEB访问方式,因当前安装介质中未找到HWI对应的WAR文件,未能进行使用学习。Hive在运行过程中,还需要提供MetaStore提供对元数据(包括表结构、表与数据文件的关系等)的保存,Hive提供三种形式的MetaStore:一是内嵌Derby方式,该方式一般用演示环境的搭建;二是采用第三方数据库进行保存,例如常用的MySQL等;三是远程接口方式,及由Hive自身提供远程服务,供其他H
4、ive应用使用。在本安装示例中采用的第二种方式进行安装部署。备注:在本文后续的安装和说明中,所有示例均以HiverServer2、Beeline方式进行。另:因Hive在查询时性能较差,后期拟计划采用SPARK或Presto进行替代,因此本安装手册不对Hive的集群方案进行描述。1.3. 环境说明本安装示例在Ubuntu 14.04.3的虚拟器中进行安装,并提前安装配置Hadoop。机器名IP地址安装软件启用服务hdfs110.68.19.184HiveHadoophdfs210.68.19.182Hadoophdfs310.68.19.183MySQLHadoop二、 MySQL安装配置2.
5、1. MySQL安装登录到hdfs3中,安装MySQL服务器。$ sudo apt-get install mysql-server修改my.cfg的配置文件$ sudo vi /etc/mysql/my.cfg修改内容如下:bind-address = 10.68.19.183:wq重新启动mysql服务$ sudo service mysql restart2.2. 创建Hive需要的数据库和用户$ mysql -uroot -p依次输入以下命令:# 创建hive用户insert into mysql.user(Host,User,Password) values(localhost,hi
6、ve,password(hive);# 创建数据库create database hive;# 授权grant all on hive.* to hive% identified by hive;grant all on hive.* to hivelocalhost identified by hive;flush privileges;# 退出exit三、 Hive安装3.1. 下载Hive从官网(http:/hive.apache.org/downloads.html)上下载最新的稳定版本地址,并上传到服务器上。本安装示例采用的版本为apache-hive-1.2.1-bin.tar.g
7、z。3.2. 解压并配置环境变量解压安装文件到/opt目录$ tar -zxvf apache-hive-1.2.1-bin.tar.gz -C /opt修改环境变量$ sudo vi /etc/profile修改如下内容export HIVE_HOME=/opt/hive-1.2.1export PATH=$JAVA_HOME/bin:$HADOOP_HOME/bin:$HIVE_HOME/bin:$PATH:wq启用配置$ source /etc/profile3.3. 修改配置文件$ cd $HIVE_HOME$ cp conf/hive-default.xml.template con
8、f/hive-site.xml$ vi conf/hive-site.xml修改以下内容的值 javax.jdo.option.ConnectionURL jdbc:mysql:/10.68.19.183:3306/hive JDBC connect string for a JDBC metastore javax.jdo.option.ConnectionDriverName com.mysql.jdbc.Driver Driver class name for a JDBC metastore javax.jdo.option.ConnectionPassword hive passwo
9、rd to use against metastore database javax.jdo.option.ConnectionUserName hive Username to use against metastore database hive.exec.local.scratchdir /data/hive/scratach Local scratch space for Hive jobs hive.downloaded.resources.dir /data/hive/download Temporary local directory for added resources in
10、 the remote file system. hive.querylog.location /data/hive/querylog Location of Hive run time structured log file hive.server2.logging.operation.log.location /data/hive/operation_logs Top level directory where operation logs are stored if logging functionality is enabled 3.4. 创建需要的目录$ mkdir /data/hi
11、ve$ mkdir /data/hive/scratach$ mkdir /data/hive/download$ mkdir /data/hive/querylog$ mkdir /data/hive/operation_logs3.5. 上传MySQL驱动将mysql-connector-java-5.1.36.jar上传到$HIVE_HOME/lib目录下。3.6. 启动$ hiveserver23.7. 基本操作验证$ beeline!connect jdbc:hive2:/hdfs1:10000输入当前用户名,密码为空或者直接输入$ ./bin/beeline u jdbc:hive
12、2:/hdfs1:10000# 查看当前数据库show databases;# 查看所有表show tables;# 创建表create table users(user_id int, fname string,lname string );# 插入数据INSERT INTO users (user_id, fname, lname) VALUES (1, john, smith);INSERT INTO users (user_id, fname, lname) VALUES (2, john, doe);INSERT INTO users (user_id, fname, lname)
13、VALUES (3, john, smith);# 查询数据select * from users limit 2;select count(1) from users;3.8. 数据导入示例示例场景说明:先将输入导入到tmp_sell_day_corp_cig,再将数据写入sell_day_corp_cig中。创建表create table tmp_sell_day_corp_cig sell_d string, cig_code string, stat_code string, statyear smallint, halfyear smallint, quarter smallint,
14、 statmonth smallint, stattenday smallint, statdate smallint, cig_province string, cig_factory string, trademark_code string, cig_inside string, cig_grade string, cig_famous string, cig_hundred string, cig_kind string, cig_low string, cig_seizure string, sell_amount double, sell_total_money double, g
15、ross_profit double, demand_amount doublepartitioned by (corp_code string)ROW FORMAT DELIMITED FIELDS TERMINATED BY ,;create table sell_day_corp_cig sell_d string, cig_code string, stat_code string, statyear smallint, halfyear smallint, quarter smallint, statmonth smallint, stattenday smallint, statd
16、ate smallint, cig_province string, cig_factory string, trademark_code string, cig_inside string, cig_grade string, cig_famous string, cig_hundred string, cig_kind string, cig_low string, cig_seizure string, sell_amount double, sell_total_money double, gross_profit double, demand_amount doublepartiti
17、oned by (corp_code string)clustered by(sell_d) sorted by(cig_code) INTO 16 BUCKETSSTORED AS orcfile;导入数据到临时表LOAD DATA LOCAL INPATH /home/whcyit/data.txt OVERWRITE INTO TABLE tmp_sell_day_corp_cig partition(corp_code=11420101);启用分桶,写入正式表set hive.enforce.bucketing = true;INSERT OVERWRITE TABLE sell_da
18、y_corp_cig partition(corp_code=11420101)select sell_d,cig_code,stat_code,statyear,halfyear,quarter,statmonth,stattenday,statdate,cig_province,cig_factory,trademark_code,cig_inside,cig_grade,cig_famous,cig_hundred,cig_kind,cig_low,cig_seizure,sell_amount,sell_total_money,gross_profit,demand_amount fr
19、om tmp_sell_day_corp_cig WHERE corp_code=11420101;显示分区SHOW PARTITIONS sell_day_corp_cig;查询数据select count(1) from sell_day_corp_cig;select sum(a.sell_amount),sum(a.sell_total_money),a.cig_code,a.corp_code from sell_day_corp_cig a group by a.cig_code,a.corp_code;建立索引create index idx_sell_day_corp_cig
20、on table sell_day_corp_cig(cig_code)as pact.CompactIndexHandler with deferred rebuild IN TABLE idx_sell_day_corp_cig_table;alter index idx_sell_day_corp_cig on sell_day_corp_cig rebuild;四、 HIVE集群配置在Hive上述的安装配置中MetaStore和HiverServer2(ThriftServer)两个部分存储单点问题,对于MetaStore因采用数据库进行保存,需要使用数据库本身的方式实现高可用。对于H
21、iverServer2的集群方式一般可以采用两种模式:一是采用HAProxy(四层应用集群)进行流量分发,二是采用ZooKeeper实现Hive集群配置。本安装仅说明采用ZooKeeper实现HiveServer2的高可用方式。4.1. ZooKeeper高可用的原理4.2. 修改hive-site.xml配置 hive.zookeeper.quorum hdfs1:2181,hdfs2:2181,hdfs3:2181 hive.server2.support.dynamic.service.discovery true hive.server2.zookeeper.namespace hiv
22、eserver2 4.3. 启动HiveServer2$ $HIVE_HOME/bin/hiveserver24.3. 验证集群启用$ zkCli.sh$ ls /hiveserver24.4.集群的使用JDBC或ODBC采用以下方式进行连接jdbc:hive2:/;serviceDiscoveryMode=zooKeeper; zooKeeperNamespace=其中:ZooKeeper地址和端口例如:String url = jdbc:hive2:/hdfs1:2181, hdfs2:2181, hdfs3:2181/;serviceDiscoveryMode=zooKeeper;zoo
23、KeeperNamespace=hiveserver2;Connection con = DriverManager.getConnection(url, whcyit, );备注:该连接方式不支持beeline客户端,当JDBC驱动能够正常运行识别。五、 Hive基础概念5.1. Hive与传统数据库的区别Hive作为基于Hadoop的数据仓库产品,虽然其采用类似数据库定义语言(DDL,create/drop/alter/truncate/show/describe)、数据库操作语言(DML:load/insert/update/delete/import/export)、SQL语言实现了数
24、据的统计分析功能,但其与传统关系型数据库有着很大区别。但Hive同样在飞速发展中,越来越多的传统数据库特性在Hive中得到了支持,例如:ACID事务特性、索引、视图等。n 不支持删除操作Hive默认情况下不支持数据删除操作,如需要删除单条记录需要启动hive的测试模式,对于实际数据仓库类应用中应不存在类似应用。对于大批量删除,只能采用重新导入数据的方式进行覆盖。n 不支持存储过程Hive没有提供存储过程的支持,对于复杂汇总依旧不能采用SQL进行有效处理。第三方提供了HPL/SQL的支持(http:/www.hplsql.org/download)还需要进一步的学习。n 不支持部分SQL特性不支
25、持主外键、条件约束;不支持类似SQL中in的用法(子查询),可以采用left semi join(半连接)进行替代;5.2. Hive支持的数据模型Hive 中所有的数据都存储在 HDFS 中,Hive 中包含以下数据模型:Table(表),External Table(外部表),Partition(分区),Bucket(桶)。Hive 中的 Table 和数据库中的 Table 在概念上是类似的,每一个 Table 在 Hive 中都有一个相应的目录存储数据。例如,一个表 app,它在 HDFS 中的路径为:/user/hive/warehouse/app。Partition(分区)对应于数
26、据库中的 Partition 列的密集索引,但是 Hive 中 Partition 的组织方式和数据库中的很不相同。在 Hive 中,表中的一个 Partition 对应于表下的一个目录,所有的 Partition 的数据都存储在对应的目录中。Buckets (桶)对指定列计算 hash,根据 hash 值切分数据,目的是为了并行,每一个 Bucket 对应一个文件。External Table指向已经在 HDFS 中存在的数据,可以创建 Partition。它和Table在元数据的组织上是相同的,而实际数据的存储则有较大的差异。Table(内部表)的创建过程和数据加载过程(这两个过程可以在同
27、一个语句中完成),在加载数据的过程中,实际数据会被移动到数据仓库目录中;之后对数据对访问将会直接在数据仓库目录中完成。删除表时,表中的数据和元数据将会被同时删除。External Table只有一个过程,加载数据和创建表同时完成(CREATE EXTERNAL TABLE LOCATION),实际数据是存储在 LOCATION 后面指定的 HDFS 路径中,并不会移动到数据仓库目录中。当删除一个 External Table 时,仅删除hive的元数据,不会删除hdfs上对应的文件。5.3. Hive的数据存储格式Hive支持以下存储格式:n TextFile文本格式(默认)。n Sequen
28、ceFileSequenceFile是Hadoop API 提供的一种二进制文件,它将数据以的形式序列化到文件中n RCFileRCFile是Hive推出的一种专门面向列的数据格式。 它遵循“先按列划分,再垂直划分”的设计理念。当查询过程中,针对它并不关心的列时,它会在IO上跳过这些列。n ORCFile全称为Optimized Row Columnaer file,针对RCFile存储格式进行一些优化。n AvroAvro是一种用于支持数据密集型的二进制文件格式。它的文件格式更为紧凑,若要读取大量数据时,Avro能够提供更好的序列化和反序列化性能。5.4. Hive支持的数据类型数值类:ti
29、nyint(1字节)、smallint(2字节)、int(4字节)、bigint(8字节)、float(4字节)、double(8字节)、decimal时间类:timestamp、date字符类:string、varchar、char其它类:boolean、binary备注:如需要使用presto、Spark等,建议采用数据类型尽量使用string、int、float、double,不要使用VARCHAR、DECIMAL等,部分第三方引擎无法提供支持。备注:通过目前初步的测试发现(3.8中的示例查询),TextFile查询约需要37s;RCFile查询需要20s左右;而ORCFile仅仅需要1
30、0s左右的时间。六、 Hive常用操作本部分只是部分常用Hive的操作指令,详细内容请查看官网WIKI上的内容(https:/cwiki.apache.org/confluence/display/Hive/Home)。6.1. 新建表CREATE TEMPORARY EXTERNAL TABLE IF NOT EXISTS db_name.table_name (col_name data_type COMMENT col_comment, .) COMMENT table_comment PARTITIONED BY (col_name data_type COMMENT col_comm
31、ent, .) CLUSTERED BY (col_name, col_name, .) SORTED BY (col_name ASC|DESC, .) INTO num_buckets BUCKETS ROW FORMAT row_format STORED AS file_format | STORED BY storage.handler.class.name WITH SERDEPROPERTIES (.) LOCATION hdfs_path6.2. 复制表结构CREATE TEMPORARY EXTERNAL TABLE IF NOT EXISTS db_name.table_n
32、ame LIKE existing_table_name LOCATION hdfs_path;6.3. 删除表DROP TABLE IF EXISTS table_name;6.4. 重命名表ALTER TABLE table_name RENAME TO new_table_name;6.5. 数据加载LOAD DATA LOCAL INPATH filepath OVERWRITE INTO TABLE tablename PARTITION (partcol1=val1, partcol2=val2 .)6.6. 数据导出EXPORT TABLE tablename PARTITION (part_column=value, .) TO export_target_path备注:路径为HDFS上的路径6.7. 数据导入IMPORT EXTERNAL TABLE new_or_original_tablename PARTITION (part_column=value, .) FROM source_path LOCATION import_target_path备注:路径为HDFS上的路径