《OD学hadoop》第四周0716
7.16
一、回顾
二、HDFS Federation(联盟)
Hadoop 2.2.0发布新特性
很多的大公司都在使用:BAT
HDFS Federation + HDFS HA架构
互相隔开,但是数据存储共用
1、新特性介绍
ViewFs Guide 视图文件系统
HDFS Snapshots 快照
在某一时刻某一个瞬间在整个文件系统中,它存储的文件具体的情况
比如:存储多少文件、它的副本数...一些信息
好处:备份、恢复
Edits Viewer
Image Viewer
用来查看fsimage和edits文件的工具
Quotas and HDFS
HDFS 配额
两种:空间、目录
C API libhdfs
可以用C语言编写MR程序,访问文件系统
2、HA和联盟的区别
HDFS HA:
两个namenode->管理同一个文件系统,内存中存储的内容是一样的。
HDFS Federation:
两个namenode各自管理属于自己一部分的数据,存储的内容完全不一样的。
namenode共同使用datanode的存储空间
namenode内存限制
注意:配置之前需要关闭原有的集群还有正在运行的服务
3、HDFS Federation配置
dfs.namenode.rpc-address:8020
datanode和namenode交互端口号
dfs.namenode.servicerpc-address:8022
减轻一个端口号的压力,可配置项
dfs.namenode.http-address:50070
浏览器访问端口
dfs.namenode.https-address:50470
浏览器访问端口
格式化所有的namenode,虽然是三个不同的namenode
但是是在一个集群中的,每个集群都有一个唯一的标识符clusterID
如果不提供ID,会自动生成一个,以免与其他集群产生冲突
三、MapReduce二次排序
MR :
input map() shuffle reduce() output
MR shuffle:
partition sort combiner compress group
排序:默认是按照key排序
分组:相同key的value放在一起
比较:key相同
指定:比较器->实现接口
key和key的比较->shuffle
需求:文件中有这些数据,依据第一个字段进行排序
如果第一个字段相同,对第二个字段进行排序
a,1 a#1,1
z,3 z#3,3
b,2 b#2,2
a,100 a#100,100
a,3 a#3,3
b,1 b#1,1
a#1,1 a#1,list<1,3,100> a,1 a,3 a,100
a#3,3
a#100,100
b#1,1
b#2,2
z#3,3
默认比较两个字段,要保持原来的第一个字段进行分组
第一个字段相同,代表key相同
这种排序是在整个shuffle阶段进行操作,并不是reduce的方法中操作的
MR本身具有排序特性:将第一个作为key,第二个字段怎么办?
直接对value进行排序?
排序消耗的CPU内存资源
【小结】mapreduce二次排序要点
1,组合key,key是一个组合字段,自定义数据类型
继承writablComparable
2、保证原来的分区,需要自定义分区partitioner,
继承partitioner
3、保持原来的分组,需要自定义分组
继承RawComparator
四、MR join
HDFS两张表:两类文件->MR分析
map join(在数据比较小的情况下可以使用)
【举例】
淘宝天猫双十一购物
1、 账户信息包括:用户ID、名称、收货地址、电话联系方式
(customer)
cid cname address telphone
2、订单信息包括:订单ID、用户ID、商品价格、商品名称
(order)
oid cid price pname
将两个表进行关联
关联之后的信息包括:用户ID、名称、收货地址、电话联系方式、商品名称
cid name address telphone pname
每个商品订单都能找到购买人
两张表->公共连接点->key(map输出的key)
cid cname address telphone(小表)
oid cid price pname(大表)
功能:
cid name address telphone pname
map-><key,value>
<cid(key), customerinfo(value)> -> <cid, customerinfo>
reduce端join(也叫shuffle join或common join)
reduce input keyvalue:
<cid, list(cinfo, orderinfo, order info, orderinfo, orderinfo)>
map
customer:
<cid,cinfo>
cinfo:
(标识)tag:customer/order
data:cinfo/orderinfo
order:
<cid,orderinfo>
五、MapReduce分布式缓存
DistributeCache
六、
Apache hadoop:
hadoop 1.x
hadoop 2.x
cloudera hadoop: -> cloudera manager
CDH3 CDH4 CDH5
hortonworks hadoop: -> yahoo
HDP 2.x
hue
《OD学hadoop》第四周0716的更多相关文章
- 《OD学hadoop》20160903某旅游网项目实战
一.大数据的落地点 1.数据出售 数据商城:以卖数据为公司的核心业务 2. 数据分析 百度统计 友盟 GA IBM analysis 3.搜索引擎 4. 推荐系统 mahout 百分比 5.精准营销 ...
- 《OD学hadoop》第三周0710
一.分布式集群安装1. Hadoop模式本地模式.伪分布模式.集群模式datanode 使用的机器上的磁盘,存储空间nodemanager使用的机器上的内存和CPU(计算和分析数据) 2. 搭建环境准 ...
- 《OD学hadoop》第三周0709
一.MapReduce编程模型1. 中心思想: 分而治之2. map(映射)3. 分布式计算模型,处理海量数据4. 一个简单的MR程序需要制定map().reduce().input.output5. ...
- 《OD学hadoop》第二周0703
hdfs可视化界面: http://beifeng-hadoop-01:50070/dfshealth.html#tab-overview yarn可视化界面: http://beifeng-hado ...
- 《OD学hadoop》第二周0702
大数据离线计算hadoop2.x 三周(6天) markdown文本剪辑器 罗振宇--跨年演讲,时间的朋友 http://tech.163.com/16/0101/11/BC87H8DF000915B ...
- 《OD学hadoop》第一周0625
一.实用网站 1. linux内核版本 www.kernel.org 2. 查看网站服务器使用的系统 www.netcraft.com 二.推荐书籍 1. <Hadoop权威指南> 1- ...
- 《OD学hadoop》Hadoop前置
一.Hadoop 前置课程 1. Linux系统,基本命令 2. Java语言,JavaSE相关知识 3. MySQL基本的DML和DDL SQL on Hadoop
- 《OD学hadoop》第一周0626 作业二:Linux基础
一.打包压缩 知识点: tar -zxvf -C PATH tar -jxvf tar -zcvf tar -jcvf tar:打包命令 -z 打包同时gzip压缩 -j 打包同时bzip2 -c 打 ...
- 《OD学hadoop》在LINUX下如何将tar压缩文件解压到指定的目录下
linux下tar命令解压到指定的目录 :#tar zxvf /bbs.tar.zip -C /zzz/bbs //把根目录下的bbs.tar.zip解压到/zzz/bbs下,前提要保证存在/zzz/ ...
随机推荐
- java 验证身份证号
- VS Bug 当获取其他项目的代码时, F5 无法进入调试模式. 也不报错....
在64位的机子下, 被获用的项目使用X86时会出现. 就会出现 F5 无法进入调试模式. 也不报错.... 打断点也没有用. 在不加入X86项目的代码时, 又可以运行.. 解决方案: 检查 ...
- nodejs快速入门
目录: 编写第一个Node.js程序: 异步式I/O和事件循环: 模块和包: 调试. 1. 编写第一个Node.js程序: Node.js 具有深厚的开源血统,它诞生于托管了许多优秀开源项目的网站—— ...
- 【算法】E.W.Dijkstra算术表达式求值
算术表达式求值 我们要学习的一个栈的用例同时也是展示泛型的应用的一个经典例子,就是用来计算算术表达式的值,例如 ( 1 + ( ( 2 + 3 ) * ( 4 * 5 ) ) ) 如果将4乘以5,把3 ...
- Goolg Chrome 插件开发--Hello world
开发Chrome插件很简单,只要会web开发(html+javascript+css)那么这个就是能驾轻就熟,只需要了解一下插件具体的运行环境及要求就OK了. 1.先创建一个html文件,名字随便取, ...
- MYSQL注入天书之数据库增删改介绍
Background-4 增删改函数介绍 在对数据进行处理上,我们经常用到的是增删查改.接下来我们讲解一下mysql 的增删改.查就是我们上述总用到的select,这里就介绍了. 增加一行数据.Ins ...
- 线上问题 - MySQL SQL state [HY000]; error code [1366]
一.问题描述 另外一个系统调用服务接口api:/xxx/create?aName=&time=&...,数据没有保存成功提示SQL state [HY000]; error code ...
- 初识IOS
编译环境: ssh cloud@10.0.4.148 mx-cloud 1.关于ARM架构 IPHONE上的ARM-CPU架构在不断的进化过程中,目前情况如下: ARMv8 / ARM64 = iP ...
- Android的px、dip、sp的区别
Android的px.dip.sp的区别 我们在页面布局的时候,经常会设置容器的长度,但是到底该使用哪个作为长度的单位而懊恼. 在Android中支持的描述大小区域的类型有以下几种: px(pix ...
- .NET Framework 框架简述01
NET技术可以以规范和实现两部分来划分. 规范: 公共语言架构(Common Language Infrastructure, CLI),主要包括 1.通用类型系统(Common Type S ...