hadoop之hdfs

前言:高可用,这个是分布式集群中不可忽略保持业务连续性的解决方案,在hadoopHDFS集群中namenode是一个”不可替代”关键角色,为了保证集群的可用性采取划分活动节点 ( Active )及 备用节点 ( Standby)


hadoop2.x 之后,Clouera 提出了 QJM/Qurom Journal Manager(还有其他的一些解决方案如:Linux HA, VMware FT, shared NAS+NFS,BookKeeper,BackupNode 等)
而QJM 主要优势如下:

不需要配置额外的高共享存储,降低了复杂度和维护成本。
消除 spof(单点故障)。
系统鲁棒性(Robust)的程度可配置、可扩展

基本原理

就是用 2N+1 台 JournalNode 存储 EditLog,每次写数据操作有>=N+1 返
回成功时即认为该次写成功,数据不会丢失了。当然这个算法所能容忍的是最多有 N
台机器挂掉,如果多于 N 台挂掉,这个算法就失效了。这个原理是基于 Paxos 算法。
在 HA 架构里面 SecondaryNameNode 已经不存在了,为了保持 standby NN 时时的
与 Active NN 的元数据保持一致,他们之间交互通过 JournalNode 进行操作同步。
任何修改操作在 Active NN 上执行时,JournalNode 进程同时也会记录修改 log
到至少半数以上的 JN 中,这时 Standby NN 监测到 JN 里面的同步 log 发生变化了会
读取 JN 里面的修改 log,然后同步到自己的目录镜像树里面


Failover Controller

HA 模式下,会将 FailoverController 部署在每个 NameNode 的节点上,作为一个单独
的进程用来监视 NN 的健康状态。 r FailoverController 主要包括三个组件: :
HealthMonitor: 监控 NameNode 是否处于 unavailable 或 unhealthy 状态。当前通过
RPC 调用 NN 相应的方法完成。
ActiveStandbyElector: 监控 NN 在 ZK 中的状态。
ZKFailoverController: 订阅 HealthMonitor 和 ActiveStandbyElector 的事件,并
管理 NN 的状态,另外 zkfc 还负责解决 fencing(也就是脑裂问题)。
上述三个组件都在跑在一个 JVM 中,这个 JVM 与 NN 的 JVM 在同一个机器上。但是两个
独立的进程。一个典型的 HA 集群,有两个 NN 组成,每个 NN 都有自己的 ZKFC 进程
ZKFailoverController 主要职责:
健康监测:周期性的向它监控的 NN 发送健康探测命令,从而来确定某个 NameNode
是否处于健康状态,如果机器宕机,心跳失败,那么 zkfc 就会标记它处于一个不
健康的状态
会话管理:如果 NN 是健康的,zkfc 就会在 zookeeper 中保持一个打开的会话,如
果 NameNode 同时还是 Active 状态的,那么 zkfc 还会在 Zookeeper 中占有一个类
型为短暂类型的 znode,当这个 NN 挂掉时,这个 znode 将会被删除,然后备用的
NN 将会得到这把锁,升级为主 NN,同时标记状态为 Active
当宕机的 NN 新启动时,它会再次注册 zookeper,发现已经有 znode 锁了,便会自
动变为 Standby 状态,如此往复循环,保证高可靠,需要注意,目前仅仅支持最
多配置 2 个 NN
r master 选举:通过在 zookeeper 中维持一个短暂类型的 znode,来实现抢占式的
锁机制,从而判断那个 NameNode 为 Active 状态


yarnHA

Yarn 作为资源管理系统,是上层计算框架(如 MapReduce,Spark)的基础。在 Hadoop2.4.0 版本之前,Yarn 存在单点故障(即 ResourceManager 存在单点故障),一旦发生故障,恢复时间较长,且会导致正在运行的 Application 丢失,影响范围较大从 Hadoop 2.4.0版本开始,Yarn 实现了 ResourceManager HA,在发生故障时自动 failover,大大提高了服务的可靠性

在一个典型的 HA 集群中,两台独立的机器被配置成 ResourceManger。在任意时间,有且只允许一个活动的 ResourceManger,另外一个备用。切换分为两种方式:

手动切换:在自动恢复不可用时,管理员可用手动切换状态,或是从 Active 到 Standby,或是从 Standby 到 Active。
自动切换:基于 Zookeeper,但是区别于 HDFS 的 HA,2 个节点间无需配置额外的 ZFKC守护进程来同步数据
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值