Hadoop 集群搭建

HADOOP集群具体来说包含两个集群:HDFS集群和YARN集群两者逻辑上分离,但物理上常在一起
HDFS集群:对文件的切分,分片存储,切分后的块也可以自己手动去利用文件追加拼出一个原文件
负责海量数据的存储,集群中的角色主要有 NameNode / DataNode
YARN集群
负责海量数据运算时的资源调度,集群中的角色主要有 ResourceManager /NodeManager
(那mapreduce是什么呢?它其实是一个应用程序开发包)

本集群搭建案例,以5节点为例进行搭建,角色分配如下:
hdp-node-01 NameNode SecondaryNameNode
hdp-node-02 ResourceManager
hdp-node-03 DataNode NodeManager
hdp-node-04 DataNode NodeManager
hdp-node-05 DataNode NodeManager

部署图:
在这里插入图片描述
一、环境准备
1、先将虚拟机的网络模式选为NAT
1.1修改主机名

		vi /etc/sysconfig/network
	
		NETWORKING=yes
		HOSTNAME=zekun ###

1.2修改IP
两种方式:

第一种:通过Linux图形界面进行修改(强烈推荐)
			进入Linux图形界面 -> 右键点击右上方的两个小电脑 -> 点击Edit connections -> 选中当前网络System eth0 -> 点击edit按钮 -> 选择IPv4 -> method选择为manual -> 点击add按钮 -> 添加IP:192.168.1.101 子网掩码:255.255.255.0 网关:192.168.1.1 -> apply
第二种:修改配置文件方式(屌丝程序猿专用)
			vim /etc/sysconfig/network-scripts/ifcfg-eth0
			
			DEVICE="eth0"
			BOOTPROTO="static"               ###
			HWADDR="00:0C:29:3C:BF:E7"
			IPV6INIT="yes"
			NM_CONTROLLED="yes"
			ONBOOT="yes"
			TYPE="Ethernet"
			UUID="ce22eeca-ecde-4536-8cc2-ef0dc36d4a8c"
			IPADDR="192.168.1.101"           ###
			NETMASK="255.255.255.0"          ###
			GATEWAY="192.168.1.1"            ###

1.3修改主机名和IP的映射关系

		vim /etc/hosts
		192.168.1.101	zekun

1.4关闭防火墙

		#查看防火墙状态
		service iptables status
		#关闭防火墙
		service iptables stop
		#查看防火墙开机启动状态
		chkconfig iptables --list
		#关闭防火墙开机启动
		chkconfig iptables off

1.5 修改sudo

		su root
		vim /etc/sudoers
		给hadoop用户添加执行的权限

		关闭linux服务器的图形界面:
		vi /etc/inittab 

1.5重启Linux

	reboot

2.安装JDK
2.1上传alt+p 后出现sftp窗口,然后put d:\xxx\yy\ll\jdk-7u_65-i585.tar.gz
2.2解压jdk

		#创建文件夹
		mkdir /home/hadoop/app
		#解压
		tar -zxvf jdk-7u55-linux-i586.tar.gz -C /home/hadoop/app

2.3将java添加到环境变量中

		vim /etc/profile
		#在文件最后添加
		export JAVA_HOME=/home/hadoop/app/jdk-7u_65-i585
		export PATH=$PATH:$JAVA_HOME/bin
	
		#刷新配置
		source /etc/profile

二、安装hadoop
1. 先上传hadoop的安装包到服务器上去 /home/hadoop/
注意:hadoop2.x的配置文件$HADOOP_HOME/etc/hadoop
伪分布式需要修改5个配置文件
2.配置hadoop
第一个:hadoop-env.sh

		vim hadoop-env.sh
		#第27行
		export JAVA_HOME=/usr/java/jdk1.7.0_65

第二个:core-site.xml

		<!-- 指定HADOOP所使用的文件系统schema(URI),HDFS的老大(NameNode)的地址 -->
		<property>
			<name>fs.defaultFS</name>
			<value>hdfs://zekun-007:9000</value>
		</property>
		<!-- 指定hadoop运行时产生文件的存储目录 -->
		<property>
			<name>hadoop.tmp.dir</name>
			<value>/home/hadoop/hadoop-2.4.1/tmp</value>
    </property>

第三个:hdfs-site.xml

		<!-- 指定HDFS副本的数量,默认值是3 -->
		<property>
			<name>dfs.replication</name>
			<value>2</value>
		</property>
		
		<property>
			<name>dfs.secondary.http.address</name>
			<value>192.168.1.152:50090</value>
		</property>

第四个:mapred-site.xml (mv mapred-site.xml.template mapred-site.xml)

		mv mapred-site.xml.template mapred-site.xml
		vim mapred-site.xml
		<!-- 指定mr运行在yarn上 -->
		<property>
			<name>mapreduce.framework.name</name>
			<value>yarn</value>
		</property>

第五个:yarn-site.xml

		<!-- 指定YARN的老大(ResourceManager)的地址 -->
		<property>
			<name>yarn.resourcemanager.hostname</name>
			<value>zekun-007</value>
		</property>
		<!-- reducer获取数据的方式 -->
		<property>
			<name>yarn.nodemanager.aux-services</name>
			<value>mapreduce_shuffle</value>
		</property>

3.将hadoop添加到环境变量

		vim /etc/proflie
		export JAVA_HOME=/usr/java/jdk1.7.0_65
		export HADOOP_HOME=/zekun/hadoop-2.4.1
		export PATH=$PATH:$JAVA_HOME/bin:$HADOOP_HOME/bin:$HADOOP_HOME/sbin
		
		source /etc/profile

4.格式化namenode(是对namenode进行初始化)

		hdfs namenode -format (hadoop namenode -format)

5.启动hadoop
①自动化
前提是先配好所有机器之间的免密登录

		先启动HDFS
		配置/etc/hadoop/slaves文件  如果本地配有ip和主机名的映射关系,在此只需要添加写上所有DataNode节点的主机名,如果没有则需要,写上所有DataNode节点的IP地址
		sbin/start-dfs.sh
		
		再启动YARN
		sbin/start-yarn.sh

②手动一台一台机器启动

		先启动HDFS
		sh hadoop-daemon.sh start  namenode //启动namenode之后即可通过50070端口访问HDFS管理界面
		sh hadoop-daemon.sh start  datanode //启动datanode之后由于配置相同,DataNode会将自己向namenode注册
		
		再启动YARN
		sbin/start-yarn.sh

6.验证是否启动成功

		使用jps命令验证
		27408 NameNode
		28218 Jps
		27643 SecondaryNameNode
		28066 NodeManager
		27803 ResourceManager
		27512 DataNode
	
		http://192.168.1.101:50070 (HDFS管理界面)
		http://192.168.1.101:8088 (MR管理界面)

三、配置ssh免登陆

	#生成ssh免登陆密钥
	#进入到我的home目录
	cd ~/.ssh
	ssh-keygen -t rsa (四个回车)
	执行完这个命令后,会生成两个文件id_rsa(私钥)、id_rsa.pub(公钥)
	将公钥拷贝到要免密登陆的目标机器上
	ssh-copy-id localhost
	---------------------------
	ssh免登陆:
		生成key:
		ssh-keygen
		复制从A复制到B上:
		ssh-copy-id B
		验证:
		ssh localhost/exit,ps -e|grep ssh
		ssh A  #在B中执行
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值