hadoop
来源:互联网 发布:手机基站测试软件 编辑:程序博客网 时间:2024/06/06 00:25
- 初识Hadoop
- 关于MapReduce
- Hive
- 安装 Apache Hadoop
- 参考文献
1.初识Hadoop
1.1 数据洪流
* 纽约证券交易所每天产生 1TB 的交易数据
* Facebook 存储着约 100 亿张照片,约 1PB 的存储容量
* The Internet Archive(互联网档案馆)存储着约 2PB 的数据,并以每月至少 20TB 的速度增长
* 瑞士日内瓦附件的大型强子对撞机每天产生约 15PB 的数据
1.2 大批量数据的存储与分析
* 存储(HDFS)
并行读取(瓶颈:带宽限制-网络传输速率)。硬件故障(避免数据丢失的常用方法是使用备份)。
* 分析(MapReduce)
大多数分析任务需要以某种方式结合大部分数据共同完成分析任务, 当这些数据分开存储的时候如何处理并保证其正确性?
在大规模分布式计算环境下,协调各进程间的执行是一个很大的挑战。最困难的是合理地处理系统部分失效问题--在不知道一个远程进程失效的情况下,同时还要继续完成整个计算。
* MapReduce 如何处理系统部分失效问题?
MapReduce 采用了无共享(shared-nothing)框架,所以 MapReduce 才能够实现失败检测,这意味着各个任务之间彼此独立,从程序员的角度看,任务的执行顺序是无关紧要的(失败了可再次运行,直至正确,对结果无影响)。MapReduce 系统本身控制 mapper 的输出结果传给 reducer 的过程,进程失效时,重新运行 reducer 比重新运行 mapper 更需要格外小心,因为 reducer 需要获取必要的 mapper 的输出结果。如果没有获得 mapper 的输出结果,必须运行相关的 mapper 重新生成输出结果。
1.3 Hadoop
Hadoop 是一个可靠的共享存储和分析系统。HDFS 实现存储,而 MapReduce 实现分析处理。
* Hadoop 起源
Hadoop 起源于 Apache Nutch,一个开源的网络搜索引擎。
HDFS:GFS -> NDFS -> HDFS。谷歌的分布式文件系统(GFS)或类似的架构,可以解决搜索引擎在网页爬取和索引过程中产生的超大文件的存储需求,且能够节省系统管理(如管理存储节点)所花的大量时间。NDFS 是基于该架构的开源实现,最终改名为HDFS。在谷歌发表 MapReduce 系统后,Nutch 的开发人员在 Nutch 上实现了一个 MapReduce 系统,并将所有的主要算法进行移植,在 NDFS 上运行 MapReduce 。
在 2006 年 2 月,NDFS 和 MapReduce 移除 Nutch 成为 Lucene 的一个子项目,这就是 Hadoop。
1.4 与关系型数据库管理系统的对比
MapReduce 比较适合以批处理的方式分析整个数据集的问题,尤其是即席分析。(一次写入,多次读取,数据分析,数据挖掘)
RDBMS 适用于“点查询”(point query)和更新,数据集被索引后,数据库系统能够提供低延迟的数据检索和快速的少量数据更新。(多次读写-更新频繁,数据管理-增删改)
2.关于MapReduce
MapReduce 是一种可用于数据处理的编程模型。MapReduce 程序本质上是并行运行的,因此可以将大规模的数据分析任务交给一个拥有足够多机器的运营商。
2.1 使用Hadoop分析数据
* map阶段和reduce阶段
MapReduce 任务过程被分为两个处理阶段:map 阶段和 reduce 阶段。每个阶段都以键/值对作为输入和输出,并由程序员选择它们的类型。
map 函数只是一个数据准备阶段,通过这种方式来准备数据,使 reduce 函数能在该准备数据上继续处理。
* 一个气象数据的例子
任务:每年全球气温的最高记录是多少?(时间跨度:一个世纪)
map 阶段的输入时原始的 NCDC 数据,行偏移量作为键,此处可忽略。
(0, 0067011990999991950051507004...99999N9+00001+999...)
(100, 0043011990999991950051507004...99999N9+00221+999...)
(328, 0043011990999991950051507004...99999N9-00111+999...)
map 函数的功能仅限于提取年份和气温信息,并将它们作为输出。
(1950, 0)
(1950, 22)
(1950, -11)
(1949, 111)
(1949, 78)
map 函数的输出经由 MapReduce 框架处理后发送到 reduce 函数,在这里为根据键/值对进行排序和分组。
(1949, [111, 78])
(1950, [0, 22, -11])
reduce 函数的功能是遍历整个输入找出最大的值。
(1949, 111)
(1950, 22)
2.2 MapReduce 在分布式文件系统中如何工作(怎样解决系统进程部分失效问题?)
当我们把数据存储在分布式文件系统中时,允许 Hadoop 将 MapReduce 计算移到存储有部分数据的各台机器上。
* 数据流
MapReduce 作业(job)是客户端需要执行的一个工作单元:它包括输入数据、MapReduce 程序和配置信息。Hadoop 将作业分成若干个小任务(task) 来执行,其中包括两类任务:map 任务和 reduce 任务。
有两类节点控制着作业执行过程:一个 jobtracker 及一系列 tasktracker。jobtracker 通过调度 tasktracker 上运行的任务,来协调所有运行在系统上作业。tasktracker在运行任务的同时将运行进度报告发送给 jobtracker, jobtracker 由此记录每项作业任务的整体进度情况。如果其中一个任务失败,jobtracker 可以去另外一个 tasktracker 节点上重新调度该任务。
Hadoop 将 MapReduce 的输入数据划分成等长的小数据块,成为输入分片(input split)或简称分片。Hadoop 为每个分片构建一个 map 任务,并由该任务来运行用户自定义的 map 函数从而处理分片中的每条记录。map 任务将其输出写入本地硬盘,而非 HDFS。
Hadoop 在存储有输入数据(HDFS 中数据)的节点上运行 map 任务,可以获得最佳性能。这就是所谓的数据本地化优化(data locality optimization)。
reduce 任务并不具备数据本地化的优势--单个 reduce 任务的输入通常来自于所有 mapper 的输出。因此,排过序的 map 输出需通过网络传输发送到运行 reduce 任务的节点。数据在 reduce 端合并,然后由用户定义的 reduce 函数处理。reduce 的输出通常存储在 HDFS 中以实现可靠存储。
* 输入分片如何切分?
对于大多数作业来说,一个合理的分片大小趋向于 HDFS 的一个块的大小,默认是 64MB。
* 只有一个 reduce 任务的数据流图
虚线框表示节点,虚线箭头表示节点内部的数据传输,而实线箭头表示节点之间的数据传输。
* 多个 reduce 任务的数据流图
map 任务和 reduce 任务之间的数据流成为 shuffle(混洗) ,因为每个 reduce 任务的输入都来自多个 map 任务。
* 没有 reduce 任务的数据流图
此时,数据处理完全并行。
* combiner
集群上的可用带宽限制了 MapReduce 作业的数量,因此最重要的一点是尽量避免 map 任务和 reduce 任务之的数据传输。Hadoop 允许用户针对 map 任务的输出指定一个合并函数--合并函数的输出作为 reduce 函数的输入。但是在 MapReduce 作业中使用 combiner 是需要慎重考虑的。
3.Hadoop 分布式文件系统
当数据集的大小超过一台独立物理计算机的存储能力时,就有必要对其进行分区(partition)并存储到若干台单独的计算机上。管理网络中跨多台计算机存储的文件系统称为分布式文件系统(distributed filesystem)。
3.1 HDFS
* 数据块(block)
默认 64M。与单一磁盘上的文件系统相似,HDFS 上的文件也被划分为块大小的多个分块(chunk),作为独立的存储单元。但与其它文件系统不同的是,HDFS 中小于一个块大小的文件不会占据整个块的空间。
* namenode
namenode 管理文件系统的命名空间。它维护着文件系统树及整棵树内的所有文件和目录。
* secondary namenode
辅助 namenode
* datanode
datanode 是文件系统的工作节点。
* jobtracker
* tasktracker
4.安装 Apache Hadoop
1) 安装 JAVA
$ yum install -y java, java-1.7.0-openjdk$ java -versionjava version "1.7.0_51"OpenJDK Runtime Environment (rhel-2.4.4.1.el6_5-x86_64 u51-b02)OpenJDK 64-Bit Server VM (build 24.45-b08, mixed mode)
2) 安装 Apache Hadoop
* 安装
$ wget http://mirror.esocc.com/apache/hadoop/common/hadoop-1.1.2/hadoop-1.1.2-1.x86_64.rpm$ rpm -ivh hadoop-1.1.2-1.x86_64.rpm
* 环境变量
$ vim /etc/hadoop/hadoop-env.sh将 export JAVA_HOME=/usr/java/default 改为 export JAVA_HOME=/usrBecause:$ vim /usr/bin/hadoop...JAVA=$JAVA_HOME/bin/java...
* 测试
$ hadoop version
3) 配置
* 配置 SSH
生成秘钥对,设置无验证 SSH 登陆,以便 Hadoop 启动集群主机集的守护进程。
$ ssh-keygen -t rsa -p '' -f ~/.ssh/id_rsa$ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys$ ssh localhost
* 独立模式(standalone 或 local mode)
无需运行任何守护进程(daemon),适合在开发阶段测试和调试 MapReduce 程序。
* 伪分布模式(pseudo-distributed model)
Hadoop 守护进程运行在本地机器上,模拟一个小规模的集群。
$ vim /etc/hadoop/hadoop-env.sh export JAVA_HOME=/usr$ vim /etc/hadoop/core-site.xml<configuration> <property>? <name>fs.default.name</name>? <value>hdfs://localhost/</value> </property></configuration>$ vim /etc/hadoop/hdfs-site.xml<configuration> <property> <name>dfs.replication</name> <value>1</value> </property></configuration>$ vim /etc/hadoop/mapred-site.xml <configuration> <property>? <name>mapred.job.tracker</name>? <value>localhost:8021</value> </property></configuration>
* 全分布模式(fully distributed model)
Hadoop 守护进程运行在一个集群上。
4) 格式化 HDFS 文件系统
在使用 Hadoop 之前,必须格式化一个全新的 HDFS 安装。通过创建存储目录和 namenode 持久化数据结构的初始版本,格式化过程创建了一个空的文件系统,格式化过程并不涉及 datanode。
$ hadoop namenode -format14/02/12 01:35:29 INFO namenode.NameNode: STARTUP_MSG:/************************************************************STARTUP_MSG: Starting NameNodeSTARTUP_MSG: host = vm1/127.0.0.1STARTUP_MSG: args = [-format]STARTUP_MSG: version = 1.2.1STARTUP_MSG: build = https://svn.apache.org/repos/asf/hadoop/common/branches/branch-1.2 -r 1503152; compiled by 'mattf' on Mon Jul 22 15:27:42 PDT 2013STARTUP_MSG: java = 1.7.0_51************************************************************/14/02/12 01:35:30 INFO util.GSet: Computing capacity for map BlocksMap14/02/12 01:35:30 INFO util.GSet: VM type = 64-bit14/02/12 01:35:30 INFO util.GSet: 2.0% max memory = 12976128014/02/12 01:35:30 INFO util.GSet: capacity = 2^18 = 262144 entries14/02/12 01:35:30 INFO util.GSet: recommended=262144, actual=26214414/02/12 01:35:30 INFO namenode.FSNamesystem: fsOwner=root14/02/12 01:35:30 INFO namenode.FSNamesystem: supergroup=supergroup14/02/12 01:35:30 INFO namenode.FSNamesystem: isPermissionEnabled=true14/02/12 01:35:30 INFO namenode.FSNamesystem: dfs.block.invalidate.limit=10014/02/12 01:35:30 INFO namenode.FSNamesystem: isAccessTokenEnabled=false accessKeyUpdateInterval=0 min(s), accessTokenLifetime=0 min(s)14/02/12 01:35:30 INFO namenode.FSEditLog: dfs.namenode.edits.toleration.length = 014/02/12 01:35:30 INFO namenode.NameNode: Caching file names occuring more than 10 times14/02/12 01:35:30 INFO common.Storage: Image file /tmp/hadoop-root/dfs/name/current/fsimage of size 110 bytes saved in 0 seconds.14/02/12 01:35:30 INFO namenode.FSEditLog: closing edit log: position=4, editlog=/tmp/hadoop-root/dfs/name/current/edits14/02/12 01:35:30 INFO namenode.FSEditLog: close success: truncate to 4, editlog=/tmp/hadoop-root/dfs/name/current/edits14/02/12 01:35:30 INFO common.Storage: Storage directory /tmp/hadoop-root/dfs/name has been successfully formatted.14/02/12 01:35:30 INFO namenode.NameNode: SHUTDOWN_MSG:/************************************************************SHUTDOWN_MSG: Shutting down NameNode at vm1/127.0.0.1************************************************************/
5) 启动和终止守护进程
* 启动
$ chmod a+x /usr/sbin/start-all.sh$ chmod a+x /usr/sbin/start-dfs.sh$ chmod a+x /usr/sbin/slaves.sh$ chmod a+x /usr/sbin/start-mapred.sh$ /usr/sbin/start-all.sh
* 终止
$ chmod a+x /usr/sbin/stop-all.sh$ chmod a+x /usr/sbin/stop-dfs.sh$ chmod a+x /usr/sbin/stop-mapred.sh$ /usr/sbin/stop-all.sh
* 测试
$ hadoop dfsadmin -report
5.构建 Hadoop 集群
a.集群的构建和安装
* 安装 JAVA
$ java -version
* 创建 Hadoop 用户
$ useradd hadoop$ groupadd hadoop
* 安装 Hadoop
在集群的主机上进行安装。
$ chmod -R hadoop:hadoop hadoop-x.y.z
b.SSH 配置
Hadoop 控制脚本依赖 SSH 来执行针对整个集群的操作。
$ ssh-keygen -t rsa -f ~/.ssh/id_rsa$ cat ~/.ssh/id_rsa.pub ~/.ssh/authorized_keys
c.Hadoop 配置
* Hadoop 配置文件
1.hadoop-env.sh2.core-site.xml3.hdfs-site.xml4.mapred-site.xml5.masters6.slaves
* 控制脚本
Hadoop 在主节点上运行指令来启动或终止集群内的守护进程。
配置文件 masters 和 slaves 记录了集群内的所有机器。各文件逐行记录一些机器的名称或 IP 地址。
masters: 配置运行 secondary namenode 的所有机器
slaves:配置运行 datanode 和 tasktracker 的所有机器
1. 在 namenode 机器上运行 HDFS 控制脚本。masters 文件包含 secondary namenode 的地址。
2. 在 jobtracker 机器上运行 MapReduce 控制脚本。
* start-dfs.sh
用于启动集群内所有的 HDFS 守护进程。
1. 在本地机器上启动一个 namenode(脚本所运行的机器)
2. 在 slaves 文件中记录的各个机器上启动一个 datanode
3. 在 masters 文件中所记录的各机器上启动一个 secondary namenode
* start-mapred.sh
用于启动集群中所有 MapReduce 守护进程。
1. 在本地机器上启动一个 jobtracker
2. 在 slaves 文件列举的每台机器上启动一个 tasktracker
4.数据操作
数据存储
数据如何保存到Hadoop中?
MySQL -> Hadoop
$ sqoop import --connect jdbc:mysql://localhost/hadoopguide --table widgets -m 1$ hadoop fs -cat widgets/part-m-00000
File -> Hadoop
$ hadoop fs -mkdir test$ hadoop fs -chmod a+w test$ hadoop fs -chmod g+w test$ hadoop fs -put a.txt test$ hadoop dfs -ls test
分析
$ hadoop jar /usr/share/hadoop/hadoop-examples-1.1.2.jar wordcount test output$ hadoop dfs -cat /user/root/output/part-r-00000
6.Hive
Hive 是一个基于 Hadoop 的数据仓库工具,它管理 HDFS 中存储的数据,可以将结构化的数据文件映射为一张数据表,并提供基于 SQL 的查询语言(运行时由引擎翻译成 MapReduce 作业)用以查询数据。
Hive 是应 Facebook 每天产生的海量新兴网络数据进行管理和学习的需求而产生和发展的。
Hive 的设计目的是让精通 SQL 技能(但 Java 编程技能相对较弱)的分析师能够在 Facebook 存放在 HDFS 的大规模数据集上运行查询。
6.1 安装
下载地址:http://www.apache.org/dyn/closer.cgi/hive/,直接解压到指定的路径即可。
$ java -version$ tar xzvf hive-0.11.0.tar.gz$ mv hive-0.11.0 /opt/hive
* 设置环境变量
$ vim ~/.bashrcexport HIVE_INSTALL=/opt/hiveexport PATH=$PATH:$HIVE_INSTALL/bin$ source ~/.bashrc$ hive
6.2 配置
$ hive --config /opt/hive/conf$ hive -hiveconf fs.default.name=localhost -hiveconf mapred.job.tracker=localhost:8021hive > SET hive.enforce.bucketing=true;
* 查看配置
不带参数的SET会列出Hive的所有配置信息。
hive > SET;hive > SET -v; #列出系统中的所有属性hive > SET fs.default.name;hive > SET mapred.job.tracker;hive > SET hive.metastore.warehouse.der;
* 开启日志
$ hive -hiveconf hive.root.logger=DEBUG,console
* 配置优先级
- Hive SET命令
- 命令行-hiveconf选项
- hive-site.xml
- hive-default.xml
- hadoop-site.xml
- hadoop-default.xml
* hive-site.xml
<configuration> <property> <name>javax.jdo.option.ConnectionURL</name> <value>jdbc:mysql://192.168.0.25:3306/metastore_db?createDatabaseIfNotExist=true</value> </property> <property> <name>javax.jdo.option.ConnectionDriverName</name> <value>com.mysql.jdbc.Driver</value> </property> <property> <name>javax.jdo.option.ConnectionUserName</name> <value>hive</value> </property> <property> <name>javax.jdo.option.ConnectionPassword</name> <value>123456</value> </property> <property> <name>hive.aux.jars.path</name> <value>file:///opt/hive/lib/hive-contrib-0.11.0.jar</value> </property></configuration>
* mysql jar
* mysql permission
6.3 常用命令
HiveSQL 一般是大小写无关的(除了字符串比较外),命令必须以分号结束,以告诉 Hive 立即执行该命令。
$ hive -f script.txt$ hive -e "SHOW TABLES"$ hive -S$ hive hive > show tables;
6.4 Hive服务
* hiveserver
让 Hive 以提供 Trift 服务的服务器形式运行,允许用不同语言编写的客户端进行访问。
* 开启服务
$ hive --service hiveserver
6.5 Hive客户端
* Hive Thrift Client
Hive Thrift 客户端简化了在多种编程语言中运行 Hive 命令。Hive 的 Thrift 绑定支持 C++、Java、PHP、Python 和 Ruby。
* Hive JDBC Driver
* Hive ODBC Driver
6.6 metastore
存储表模式及相对应的 Hadoop 文件等信息。
* Embedded metastore configuration
默认情况下,metastore 服务和 Hive 服务运行在同一个 JVM 中,它包含一个内嵌的以本地磁盘作为存储的 Derby 数据库实例。此时,你只能为每个 metastore 打开一个 Hive 会话。
hive > SET javax.jdo.option.ConnectionURL;javax.jdo.option.ConnectionURL=jdbc:derby:;databaseName=metastore_db;create=true
* Local metastore
使用独立的数据库以支持多会话(以及多用户)。
$ touch /opt/hive/conf/hive-site.xml<configuration><property><name>javax.jdo.option.ConnectionURL</name><value>jdbc:mysql://192.168.0.250:3306/metastore_db?createDatabaseIfNotExist=true</value></property><property><name>javax.jdo.option.ConnectionDriverName</name><value>com.mysql.jdbc.Driver</value></property><property><name>javax.jdo.option.ConnectionUserName</name><value>hive</value></property><property><name>javax.jdo.option.ConnectionPassword</name><value>123456</value></property></configuration>$ cp mysql-connector-java-5.1.25-bin.jar /opt/hive/lib/mysql > grant all privileges on *.* to 'hive'@'%' identified by '123456';mysql > flush privileges;mysql > source /opt/hive/scripts/metastore/upgrade/mysql/hive-schema-0.10.0.mysql.sql
* Remote metastore
hive > SET hive.metastore.localfalsehive > SET hive.metastore.uristhrift://host:port,...
6.7 HiveSQL
HiveSQL 是 SQL 的方言(dialect),它并不完全支持 SQL-92 标准。
* 复杂数据类型
hive > CREATE TABLE complex ( > col1 ARRAY<INT>, > col2 MAP<STRING, INT>, > col3 STRUCE<a:STRING, b:INT, c:DOUBLE> > );hive > SELECT col1[0],col2['b'], col3.c FROM complex;
* 函数
hive > SHOW FUNCTIONS;hive > DESCRIBE FUNCTION length;
6.8 托管表和外部表
* 托管表(managed table)
数据归Hive管理,存放在/user/hive/warehouse/table。
hive > CREATE TABLE test(id INT, col1 STRING) > ROW FORMAT DELIMITED FIELDS TERMINATED BY '\t';hive > LOAD DATA LOCAL INPATH '/tmp/test.txt' OVERWRITE INTO TABLE test;hive > LOAD DATA INPATH '/user/root/test/*' OVERWRITE INT TABLE test;$ hadoop fs -ls /user/hive/warehouse/test
* 外部表(external table)
数据不归Hive管理,数据存放路径需在定义表时指定。
hive > CREATE EXTERNAL TABLE test (value STRING) > LOCATION '/user/root/test';hive > LOAD DATA INPATH '/user/root/a.txt' OVERWRITE INTO TABLE test;hive > LOAD DATA LOCAL INPATH '/tmp/a.txt' OVERWRITE INTO TABLE test;
* 托管表和外部表的区别
删除表时,托管表会连数据一起删除,外部表不会。
hive > DROP TABLE test;$ hadoop fs -ls /user/hive/warehouse/test #托管表数据存放路径$ hadoop fs -ls /user/root/test #外部表数据存放路径
6.9 分区和桶
* 分区(partition)
使用分区可以加快数据分片(slice)的查询速度。
根据分区条件把文件放到分区文件夹中,相当于根据分区条件进行了一次过滤,那么根据分区进行条件查询会比未分区快。
使用分区时相关的列会转换成对应的目录名称,数据文件不再保存分区列(partition column)的数据,即 PARTITION BY 子句中的列定义是表中正式的列,它的值就是目录名。
hive > CREATE TABLE test (col2 STRING, col4 STRING) > PARTITIONED BY (col1 STRING, col3 STRING) > ROW FORMAT DELIMITED FIELDS TERMINATED BY '\t';hive > LOAD DATA LOCAL INPATH '/tmp/test.txt' INTO TABLE test > PARTITION (col1='a', col3='c');hive > SHOW PARTITIONS test;
* 桶(bucket)
为数据提供额外的结构以获得更高效的查询处理。
连接两个在(包含连接列的)相同列上划分了桶的表,可以使用 map 端连接(map-side join)高效地实现。
我们使用 CLUSTERED BY 子句来指定划分桶所用的列和要划分的桶的个数:
hive > SET hive.enforce.bucketing=true;hive > CREATE TABLE bucketed_users(id INT, name STRING) > CLUSTERED BY (id) INTO 4 BUCKETS;hive > CREATE TABLE bucketed_users(id INT, name STRING) > CLUSTERED BY (id) SORTED BY (id ASC) INTO 4 BUCKETS;hive > INSERT OVERWRITE TABLE bucketed_users > SELECT * FROM users;hive > SELECT * FROM bucketed_users > TABLESAMPLE(BUCKET 2 OUT OF 4 ON day); #取其中1桶的数据hive > SELECT * FROM bucketed_users > TABLESAMPLE(BUCKET 1 OUT OF 2 ON day); #取一半的数据
6.10 存储格式
Hive 从两个维度对表的存储进行管理: “行格式”(row format)和“文件格式”(file format)。
行格式指行和一行中的字段如何存储。Hive 中的行格式由 SerDe 定义。SerDe 是 “序列化和反序列化工具” (Serializer - Deserializer)的合成词。
* 默认存储格式:分隔的文本(delimited text)
hive > CREATE TABLE test(id INT, value STRING) > ROW FORMAT DELIMITED > FIELDS TERMINATED BY '\t';
* RegexSerDe
hive > CREATE TABLE stations (usaf STRING, wban STRING, name STRING) > ROW FORMAT SERDE 'org.apache.hadoop.hive.contrib.serde2.RegexSerDe' > WITH SERDEPROPERTIES ( > "input.regex" = "(\\d{6})(\\d{5})(.{29}) .*" > );
* Apache Access Log
hive > CREATE TABLE apache_access_log ( > host STRING, > identity STRING, > user STRING, > time STRING, > request STRING, > status STRING, > size STRING, > referer STRING, > agent STRING > ) > ROW FORMAT SERDE 'org.apache.hadoop.hive.contrib.serde2.RegexSerDe' > WITH SERDEPROPERTIES ( > "input.regex" = "([^ ]*) ([^ ]*) ([^ ]*) (-|\\[[^\\]]*\\]) ([^ \"]*|\"[^\"]*\") (-|[0-9]*) (-|[0-9]*)(?: ([^ \"]*|\".*\") ([^ \"]*|\".*\"))?", > "output.format.string" = "%1$s %2$s %3$s %4$s %5$s %6$s %7$s %8$s %9$s" > ) > STORED AS TEXTFILE; hive > LOAD DATA LOCAL INPATH '/var/log/apache/access_log' INTO TABLE apache_access_log;hive > select * from apache_access_log;
6.11 导入数据
* INSERT OVERWRITE TABLE
hive > INSERT OVERWRITE TABLE target > SELECT * FROM source;hive > INSERT OVERWRITE TABLE target > PARTITION (dt='2013-07-18') > SELECT col1, col2 FROM source;
* 动态分区插入
hive > SET hive.exec.dynamic.partition=true;hive > INSERT OVERWRITE TABLE target > PARTITION (dt) > SELECT col1, col2, dt FROM source;
* 多表插入
hive > FROM srouce > INSERT OVERWRITE TABLE target1 > SELECT col1, COUNT(col2) GROUP BY col1 > INSERT OVERWRITE TABLE target2 > SELECT col1, COUNT(DISTINCT col2) GROUP BY col1 > INSERT OVERWRITE TABLE target3 > SELECT col1, COUNT(col2) WHERE col3='2013' GROUP BY col1;
* CREATE TABLE ... AS SELECT
CTAS 是原子操作,因此如果 SELECT 查询由于某种原因失败,是不会创建新表的。
hive > CREATE TABLE target > AS > SELECT col1, col2 FROM source;
6.12 查询
* 内连接
hive > SELECT * > FROM sales > JOIN things ON (sales.id = things.id);
* 外连接
hive > SELECT * > FROM sales > LEFT OUTER JOIN things ON (sales.id = things.id);hive > SELECT * > FROM sales > RIGHT OUTER JOIN things ON (sales.id = things.id);hive > SELECT * > FROM sales > FULL OUTER JOIN things ON (sales.id = things.id);
* 半连接
hive > SELECT * > FROM things > LEFT SEMI JOIN sales ON (sales.id = things.id);
* map 连接
hive > SELECT /*+ MAPJOIN(things) */ sales.*, things.* > FROM sales > JOIN things ON (sales.id = things.id);
6.13 Functions
* to_date
hive > select to_date(created_at) from access_log;
6.14 FAQ
* 如何处理分片日志?
Hive支持文件夹的方式,将文件夹内的所有文件,都load到指定表中。HDFS会将文件系统内的某文件夹路径内的文件,分散到不同的实际物理地址中。这样,在数据量很大的时候,Hive支持读取多个文件载入,而不需要限定在唯一的文件中。
hive > LOAD DATA LOCAL INPATH '/tmp/test/*.txt' OVERWRITE INTO TABLE test PARTITION(pt=’xxxx);
7.缺点
- 单点故障
- 用于数据分析,数据交互弱:修改和删除?
8.FAQ
* 集群中的datanode存储空间如何分配?
参考文献
- 云计算关键技术及基于Hadoop的云计算模型研究: http://wenku.baidu.com/view/5748b911a21614791711287c.html
- jdk安装:http://mr-know.blog.163.com/blog/static/2862703201298115242492/
- 启动异常:http://hi.baidu.com/xixitie/item/60da2daa926537ab29ce9d9a
- Hadoop之安装配置及测试案例:http://www.24xuexi.com/w/2011-04-23/88684.html
- hive安装配置与调试: http://wenku.baidu.com/view/55485a3483c4bb4cf7ecd1eb.html
- hadoop安装配置指南:http://wenku.baidu.com/view/91e0240b52ea551811a68706.html
- Hadoop和Hive的数据处理流程:http://www.cnblogs.com/ggjucheng/archive/2012/07/25/2608757.html
- hive数据导入: http://blog.csdn.net/yfkiss/article/details/7776406
- 基于Hadoop_Hive的web日志分析系统的设计: http://www.doc88.com/p-1764773680100.html
- hive日志系统实战: http://wenku.baidu.com/view/7f2a7f62ddccda38376baf0e.html
- hive导入
- HIVE sql 学习笔记: http://blog.csdn.net/iquicksandi/article/details/8515429
- hadoop
- Hadoop
- Hadoop
- hadoop
- hadoop
- Hadoop
- Hadoop
- hadoop
- Hadoop
- hadoop
- hadoop
- hadoop
- hadoop
- Hadoop
- Hadoop
- hadoop
- Hadoop
- Hadoop
- 各种错误
- Unity3D 移动开发代码优化
- 人生感悟
- findbugs 错误分析
- 针对一些异常处理方法
- hadoop
- 一段神奇的js代码
- C# yield return 的作用
- 用nohup执行python程序时,print无法输出
- 文本相似度——编辑距离算法&java简单实现
- unity3d 从0开始学
- Android编译之MAKE
- 浏览器发送URL的编码特性
- 带指针参数的函数指针数组