使用QJM部署HDFS HA集群
一、所需软件
1. JDK版本
下载地址:http://www.oracle.com/technetwork/java/javase/index.html
版本: jdk-7u79-linux-x64.gz
2. Hadoop软件
下载地址:http://hadoop.apache.org/releases.html
版本: hadoop-2.6.0.tar.gz
二、配置ssh免密码登陆:
查阅之前博客:http://www.cnblogs.com/yinchengzhe/p/4967928.html
三、环境说明
主备NameNode有多种配置,本文采用QJM(Quorum Journal Manager) ,主备NameNode应位于不同机器上
集群中包括4个节点:1个Master,3个Salve,节点之间局域网连接,可以相互ping通。
本人有3台云主机,主机名分别为h1,h2,h3。由于资源紧缺,master和其中一个salve共用h1主机。
搭建手动切换ha集群,较自动切换少了一个zookeeper集群。
主机分布情况如下:
h1: master namenode(主) journalnode datanode
h2: salve namenode(备) journalnode datanode
h3: salve journalnode datanode
四、HDFS HA (QJM)集群安装
1. 在h1上解压hadoop-2.6.0.tar.gz并重命名为hadoop
> tar zxvf hadoop-2.6.0.tar.gz
> mv hadoop-2.6.0 hadoop
2. 配置hadoop-env.sh
配置jdk路径,如: export JAVA_HOME=/root/software/jdk1.7.0_79
3. 配置core-site.xml
修改Hadoop核心配置文件core-site.xml,这里配置的是HDFS的地址和端口号
> cd /hadoop/etc/hadoop
> vim core-site.xml
配置如下:

注:此处h1为本机的hostname
4. 配置slaves
此配置为master主机特有,配置此文件有两种方式
第一种:去掉"localhost",每行只添加一个主机名,把所有的Slave主机名都填上。
如:h1
h2
h3
第二种: 去掉"localhost",加入集群中所有Slave机器的IP,也是每行一个。
如:192.168.1.1
192.168.1.2
192.168.1.3
5. 配置hdfs-site.xml
如下所示:

(1). dfs.nameservices
集群中命名服务列表(自定义)
(2). dfs.ha.namenodes.[nameservice ID]
命名服务中的namenode逻辑名称(自定义)
(3). dfs.namenode.rpc-address.[nameservice ID].[name node ID]
命名服务中逻辑名称对应的RPC地址
(4). dfs.namenode.http-address.[nameservice ID].[name node ID]
命名服务中逻辑名称对应的HTTP地址
(5). dfs.namenode.name.dir
NameNode fsiamge存放目录
(6). dfs.namenode.shared.edits.dir
主备NameNode同步元信息的共享存储系统
(7). dfs.journalnode.edits.dir
Journal Node数据存放目录
6. 将h1上的hadoop文件夹复制到h2、h3节点上
7. 启动关闭HDFS
步骤1:在各个JournalNode节点上,输入以下命令启动journalnode服务:
> sbin/hadoop-daemon.sh start journalnode
步骤2:在[nn1]上,对其进行格式化,并启动:
> bin/hdfs namenode -format
> sbin/hadoop-daemon.sh start namenode
步骤3:在[nn2]上,同步nn1的元数据信息:
> bin/hdfs namenode -bootstrapStandby
步骤4:在[nn2],启动NameNode:
> sbin/hadoop-daemon.sh start namenode
(经过以上四步操作,nn1和nn2均处理standby状态)
步骤5:在[nn1]上,将NameNode切换为Active
> bin/hdfs haadmin -transitionToActive nn1
步骤6:在[nn1]上,启动所有datanode
> sbin/hadoop-daemons.sh start datanode
启动成功可通过jps命令查看结果,如下所示:



关闭:
在[nn1]上输入命令 sbin/stop-dfs.sh
8. HDFS WEB界面浏览
Windows访问Linux方式参照 http://www.cnblogs.com/yinchengzhe/p/5012936.html
启动hdfs后界面如下:


使用QJM部署HDFS HA集群的更多相关文章
- 手动部署 kubernetes HA 集群
前言 关于kubernetes HA集群部署的方式有很多种(这里的HA指的是master apiserver的高可用),比如通过keepalived vip漂移的方式.haproxy/nginx负载均 ...
- JAVA API连接HDFS HA集群
使用JAVA API连接HDFS时我们需要使用NameNode的地址,开启HA后,两个NameNode可能会主备切换,如果连接的那台主机NameNode挂掉了,连接就会失败. HDFS提供了names ...
- 菜鸟玩云计算之十八:Hadoop 2.5.0 HA 集群安装第1章
菜鸟玩云计算之十八:Hadoop 2.5.0 HA 集群安装第1章 cheungmine, 2014-10-25 0 引言 在生产环境上安装Hadoop高可用集群一直是一个需要极度耐心和体力的细致工作 ...
- ZooKeeper学习之路 (九)利用ZooKeeper搭建Hadoop的HA集群
Hadoop HA 原理概述 为什么会有 hadoop HA 机制呢? HA:High Available,高可用 在Hadoop 2.0之前,在HDFS 集群中NameNode 存在单点故障 (SP ...
- 菜鸟玩云计算之十九:Hadoop 2.5.0 HA 集群安装第2章
菜鸟玩云计算之十九:Hadoop 2.5.0 HA 集群安装第2章 cheungmine, 2014-10-26 在上一章中,我们准备好了计算机和软件.本章开始部署hadoop 高可用集群. 2 部署 ...
- Canalv1.1.4版本搭建HA集群
前提 Canal上一个正式版是于2019-9-2发布的v1.1.4,笔者几个月前把这个版本的Canal推上了生产环境,部署了HA集群.过程中虽然遇到不少的坑,但是在不出问题的前提下,Canal的作用还 ...
- HDFS的HA集群原理分析
1.简单hdfs集群中存在的问题 不能存在两个NameNode 单节点问题 单节点故障转移 2.解决单节点问题 找额外一个NameNode备份原有的数据 会出现脑裂 脑裂:一个集群中多个管理者数据 ...
- Hadoop HA集群 与 开发环境部署
每一次 Hadoop 生态的更新都是如此令人激动 像是 hadoop3x 精简了内核,spark3 在调用 R 语言的 UDF 方面,速度提升了 40 倍 所以该文章肯定得配备上最新的生态 hadoo ...
- Hadoop(HDFS,YARN)的HA集群安装
搭建Hadoop的HDFS HA及YARN HA集群,基于2.7.1版本安装. 安装规划 角色规划 IP/机器名 安装软件 运行进程 namenode1 zdh-240 hadoop NameNode ...
随机推荐
- C#中方法的参数修饰符
做项目久了,有的时候真的需要静下心来认真的总结一下自己所用到的技术,而不是每天依葫芦画瓢,每天忙忙碌碌,到头来不知道自己忙了个啥,学了什么,自己到底掌握了多少知识.所以我想回顾一下C#的基础知识,把重 ...
- 6 关于 Oracle NULL栏位和PL./SQL执行实验
今日有针对NULL值有了相关实验. 对NULL 值插入的讨论. 1, PL/SQL 中可以执行插入''或者NULL 的操作, 前提是栏位允许为空. 2, 可以对NULL进行一系列数据库运算. 如: ...
- C# 之【获取网页响应码200】
做了个监控网站的C#项目,判断网站是否运行正常,采用的就是获取HTTP头返回的状态码. 比如状态码为200的就是网站正常,403是Forbidden,404是网页未找到这样. 代码如下: 首先是使用库 ...
- ios专题 - APP设计流程
网上看到这篇文章,觉得基本的flow很有帮助,转过来收藏了:作者:关于Sarah Parmenter英国艾塞克斯(英国英格兰东南部的郡)Youknowwho设计工作室的创始人,Sarah Parmen ...
- Centos安装编译环境
众所周知,在安装完Centos完了以后,是没有编译环境的,我自己挂上光盘,手动安装解决了几十的依赖关系,在配置些软件时,还是经常报些依赖软件包的缺失,很是头疼,后来百度了下centos需要装的编译环境 ...
- 学习笔记-记ActiveMQ学习摘录与心得(一)
这两天在看开源的MQ技术,趁着晚上安静,把这两天学的东西摘录下.在公司学东西效率真心捉鸡,心里总觉得别扭,拿了公司的钱不干活还在那学习,表示心情不淡定,效率不行啊...晚上时间是我的,下班还是蛮开心的 ...
- js学习--DOM操作详解大全 前奏(认识DOM)
一 . 节点属性 DOM 是树型结构,相应的,可以通过一些节点属性来遍历节点树: 方法 说明 nodeName 节点名称,相当于tagName.属性节点返回属性名,文本节点返回#text.nodeNa ...
- word2007在试图打开文件时遇到错误解决方法
当您尝试在 Microsoft Office Word 2007 中打开 .docx 文件时,该文件打不开.此外,您还会收到以下错误消息: Word 在试图打开文件时遇到错误.请尝试下列方法:* 检查 ...
- PDF转图片 C# with Adobe API
PDF转图片大概有十几种方式,褒贬不一,我就详细给大家说一下我认为效率最高的方式,使用Adobe官方的SDK 安装acrobat reader 9.0以上即可,勾选如下组件.
- Streams and .NET
http://www.codeguru.com/csharp/csharp/cs_data/streaming/article.php/c4223/Streams-and-NET.htm In thi ...