大数据指无法在一定时间范围内用常规软件工具进行捕捉/管理和梳理的数据集合,需要新处理模式才能具有更强的决策力/洞查发现力和流程优化能力的海量/高增长率和多样化的信息资产
-是指从各种类型的数据中,库阿斯获得有价值的信息
企业组织利用相关数据分析帮助他们降低成本,提高效率,开发[新产品,做出更明智的业务决策等
-把数据集合后进行分析的信息和数据关系性,用来擦觉商业趋势,判定研究质量,避免疾病扩散,打击犯罪或测定即使交通路况等
-大规模并行处理数据库,数据挖掘电网,分布式文件系统或数据库,云计算平和可扩展的存储系统
volume 大体量 可从数百TB到数十数百PB,甚至EB的规模
-variety 多样性 大数据包括各种格式和形态的数据
-velocity 时效性 很多数据需要在一定的时间限度下得到及时处理
-veracity 准确性 处理的结构要保证一定的准确性
-value 大价值 大数据包含很多深度的加载,大数据分析挖掘和;利用将带来巨大的商业价值
Hadoop 是一种分析和处理海量数据库的软件平台
-hadoop 是一款开源软件,使用java开发
-hadoop 可以提供一个分布式基础架构
高可靠,高扩展性,高效性,高容错性,低成本
HDFS:hadoop分布式文件系统(核心组件)
MapReduce:分布式计算框架(核心组件)
Yarn:集群资源管理系统(核心组件)
zookeeper:分布式协作服务
hbase:分布式列存数据库
hive:基于hadoop的数据仓库
sqoop:数据同步工具
pig:基于hadoop的数据流系统
mahout:数据挖掘算法库
flume:日志收集工具
HDFS :hadoop体系中数据存储管理的基础,是一个高度容错的系统,用于低成本的通用硬件上运行
client
-namenode
-secondarynode
-datanode
Namenode : Master节点,管理HDFS的名称空间和数据块映射信息,配置副本策略,处理所有客户端请求
secondary Namenode
-定期合并fsimage 和fsedits
-紧急情况下,可辅助恢复Namenode
但secondary NameNode 并非NameNode的热备
数据存储节点,存储实际的数据
-汇报存储信息给NameNode
切分文件
-访问HDFS
-与NameNode交互,获取文件位置信息
-与DataNode交互,读取和写入数据
每块缺省128M大小
-每块可以多个副本
tasktracker
-map task
-reduce task
Master节点只有一个
-管理所有作业/任务的监控,错误处理等
-将任务分解成;一系列任务,并分派给task tracker
slave节点,一般是多台
-运行map task 和reduce task
-并与jobTracker 交互,汇报状态
map task :解析每条数据记录,传递给用户编写的map()并执行,将输出结果写入本地磁盘
-如果为map-only作业,直接写入HDFS
reduce task :从map task 的执行结果中,远程读取输入数据,对数据进行排序,将数据按照分组传递给用户编写的reduce函数执行
resourcemanager
-nodemanager
–applicationmaster
–container
–client
处理客户端请求
-启动/监控applicationManager
-监控nodemanager
-资源分配与调度
单个节点上的资源管理
-处理来自resourcemanager的命令
-处理来自applicationmaster的命令
对任务运行环境的抽象,封装了CPU,内存等
-多维资源以及环境变量,启动命令等任务运行相关的资源分配与调度
数据切分
-为应用程序申请资源,[分配给内部任务
-任务监控与容错
用户与Yarn交互的客户端程序
-提交应用程序,监控应用程序状态,杀死应用程序
将jabtracker和task Tracker进行分离,她由以下几大构成组件
-ResourceManager一个全局的资源管理器
-Nodemanager每个节点RM代理
-ApplicationManager表示每个应用
-每一个ApplicationMaster有多个Container在Nodemanager上运行
-单机
-伪分布式
-完全分布式
真机提供hadoop软件或者官网下载http://hadoop.apache.org
[root@room12pc14 home]# cd /linux-soft/04/
[root@room12pc14 04]# ls
ansible docker elk hadoop openstack
[root@room12pc14 04]# scp -r hadoop/ [email protected]:/root //拷贝给真机
zookeeper-3.4.13.tar.gz 100% 35MB 135.6MB/s 00:00
kafka_2.12-2.1.0.tgz 100% 53MB 123.2MB/s 00:00
hadoop-2.7.7.tar.gz 100% 209MB 88.2MB/s 00:02
[root@nn01 ~]# yum -y install java-1.8.0-openjdk-devel
[root@nn01 ~]# java -version
openjdk version “1.8.0_131”
OpenJDK Runtime Environment (build 1.8.0_131-b12)
OpenJDK 64-Bit Server VM (build 25.131-b12, mixed mode)
[root@nn01 ~]# jps
1235 Jps
[root@nn01 ~]# ls
hadoop
[root@nn01 ~]# cd hadoop/
[root@nn01 hadoop]# ls //查看获取到了软件
hadoop-2.7.7.tar.gz kafka_2.12-2.1.0.tgz zookeeper-3.4.13.tar.gz
[root@nn01 hadoop]# tar -xf hadoop-2.7.7.tar.gz //解包
[root@nn01 hadoop]# ls
hadoop-2.7.7 kafka_2.12-2.1.0.tgz
hadoop-2.7.7.tar.gz zookeeper-3.4.13.tar.gz
[root@nn01 hadoop]# mv hadoop-2.7.7 /usr/local/hadoop //改路径
[root@nn01 hadoop]# cd /usr/local/hadoop
[root@nn01 hadoop]# ls
bin include libexec NOTICE.txt sbin
etc lib LICENSE.txt README.txt share
[root@nn01 hadoop]# ./bin/hadoop //报错,hadoop找不到java
Error: JAVA_HOME is not set and could not be found.
[root@nn01 hadoop]# rpm -ql java-1.8.0-openjdk //查找java安装路径
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64/jre/bin/policytool
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64/jre/lib/amd64/libawt_xawt.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64/jre/lib/amd64/libjawt.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64/jre/lib/amd64/libjsoundalsa.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64/jre/lib/amd64/libsplashscreen.so
/usr/share/applications/java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64-policytool.desktop
/usr/share/icons/hicolor/16x16/apps/java-1.8.0.png
/usr/share/icons/hicolor/24x24/apps/java-1.8.0.png
/usr/share/icons/hicolor/32x32/apps/java-1.8.0.png
/usr/share/icons/hicolor/48x48/apps/java-1.8.0.png
[root@nn01 hadoop]# cd ./etc/hadoop/ //进入下2层目录
[root@nn01 hadoop]# ls
capacity-scheduler.xml hadoop-policy.xml kms-log4j.properties ssl-client.xml.example
configuration.xsl hdfs-site.xml kms-site.xml ssl-server.xml.example
container-executor.cfg httpfs-env.sh log4j.properties yarn-env.cmd
core-site.xml httpfs-log4j.properties mapred-env.cmd yarn-env.sh
hadoop-env.cmd httpfs-signature.secret mapred-env.sh yarn-site.xml
hadoop-env.sh httpfs-site.xml mapred-queues.xml.template
hadoop-metrics2.properties kms-acls.xml mapred-site.xml.template
hadoop-metrics.properties kms-env.sh slaves
[root@nn01 hadoop]# vim hadoop-env.sh //修改配置文件2行
25 export JAVA_HOME="/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64/jre"
33 export HADOOP_CONF_DIR="/usr/local/hadoop/etc/hadoop"
[root@nn01 hadoop]# cd /usr/local/hadoop //进入目录
[root@nn01 hadoop]# pwd
/usr/local/hadoop
[root@nn01 hadoop]# ls
bin etc include lib libexec LICENSE.txt NOTICE.txt README.txt sbin share
[root@nn01 hadoop]# ./bin/hadoop //运行
Usage: hadoop [–config confdir] [COMMAND | CLASSNAME]
…
Most commands print help when invoked w/o parameters.
[root@nn01 hadoop]# mkdir /usr/local/hadoop/input //创建收集目录
[root@nn01 hadoop]# ls
bin etc include input lib libexec LICENSE.txt NOTICE.txt README.txt sbin share
[root@nn01 hadoop]# cp *.txt /usr/local/hadoop/input //拷贝文件到收集目录
[root@nn01 hadoop]# ./bin/hadoop jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.7.7.jar wordcount input output //调用jar包,运行,输入文件,输出文件
[root@nn01 hadoop]# cat output/part-r-00000 //查看统计结果,没有排序
…配置和测试完成…