Hadoop学习笔记1-如何简单布署hadoop
企业机型配置:
选型标准:普通的,廉价的,标准的(容易替换的),工业化大规模生产的
CPU:支持多核CPU,如2个4核CPU
内存:16G以上,内存越大,常用数据都缓存在内存,提高速度
硬盘:不需RAID,也不需使用SCSI、SAS、SSD硬盘,只需普通SATA硬盘即可,只要容量足够。
网络:建议千兆网和高带宽交换机,hadoop对各节点服务器的数据通讯量极为重要。Infinband可以不用考虑。
网络拓扑设计:
使用局域网布署,尽量不使用低速率的跨数据中心连接。
hadoop支持机架感知机制。

操作系统选择:
主流操作系统:Linux,只要是最新版即可,例:CentOs, Unbuntu, Redhat等。
window下需要cygwin,但可能出现意料不到的问题。
不区分32/64位数,基于Java环境。
实验布署环境:
伪分布模式:在单机环境下同时启动namenode,datanode,jobtracker,tasktracker, secondary namenode等五个进程,即多个节点都模拟运行在一台机下。
完全分布模式:正常的hadoop集群,由多个各司其职的节点构成。
以CentOs虚拟机为例:
可使用默认分区,CLI界面即可。
需要安装ssh,vi,java最新版。
注意需要将iptables, selinux等防火墙关闭。
配置工作:
- 配置hosts文件:
在各节点的系统内设置好各节点的IP和对应的主机名,文件位置:/etc/hosts。
以此步骤以便各节点能根据主机名称找到该机器以便通讯,防止局域网IP可能某些原因而变化导致找不到相应机器而通讯失败。
此步骤应最先设置好。
- 建立hadoop运行的帐号。
- 配置免密码ssh:
需要生成密钥复制到各节点中,使各节点之间达到ssh的免密码连接。
注意:
- 密钥文件的权限数为644,即rw-r—r—
- 各节点的密钥也要复制一份给自身,达到ssh免密码连接访问自身。
CentOs 6默认安装了ssh,只需确认sshd服务是否自启动即可。ssh需要手动安装:yum install openssh-clients。
免密码方法设置:http://www.cnblogs.com/xiwang6428/p/3451711.html
- 下载解压或安装hadoop安装包。
一般是下载tar.gz压缩包,可解压在用户的家目录下。
- 配置hadoop相关文件:(以1.2版为例,位于hadoop目录/conf/)
|
文件名 |
格式 |
描述 |
修改配置 |
|
hadoop-env.sh |
bash脚本 |
运行hadoop所需的环境变量 |
设置export JAVA_HOME=java的安装目录 |
|
core-site.xml |
xml配置文件 |
配置hadoop核心设置,如HDFS和MadReduce的I/O设置 |
在<configuration>节点间加入: <property> <name>fs.default.name</name> #指定namenode名称节点 <value>hdfs://namenode主机名:9000</value> </property> <property> <name>hadoop.tmp.dir</name> #指定hadoop的临时目录,如果不设定会默认以/tmp为临时目录。该目录会自动清空,所以不要用。 <value>/home/hadoop运行的用户帐号/hadoop/tmp</value> </property> |
|
hdfs-site.xml |
xml配置文件 |
配置HDFS守护进程:namenode,secondary namenode和datanode。 |
在configuration节点添加: <property> <name>dfs.replication</name> #指定数据复制份数,一般来说有几个数据节点就复制几份 <value>2</value> </property> |
|
mapred-site.xml |
xml配置文件 |
配置mapreduce进程:jobtracker和tasktracker |
在configuration节点添加: <property> <name>mapred.job.tracker</name> #设定jabtracker的监听地址和端口 <value>namenode主机名:9001</value> </property> |
|
masters |
文本文件 |
运行主要的次要的namenode的主机名列表(每行一个) |
每行添加一个主机名 |
|
slaves |
文本文件 |
运行datanode和tasktracker的主机名列表(每行一个) |
每行添加一个主机名 |
- 将配置好的hadoop目录分发复制到各节点的主机内。
因为各机的配置都相同,所以直接复制过去即可。
例:scp –r ./hadoop 目标主机名:/home/用户名
- 格式化分布式文件系统:
在namenode主机的hadoop目录下,执行 bin/hadoop namenode –format
出现一堆信息,如成功有提示:has been successfully formatted.
- 启动守护进程:
在namenode主机的hadoop目录下,执行 bin/start-all.sh
相关的启动信息会记录在各节点主机的 hadoop目录/logs下。
- 检测守护进程启动情况
/usr/java/jdk1.6.0_26/jps #假设此为java安装目录
Hadoop学习笔记1-如何简单布署hadoop的更多相关文章
- hadoop学习笔记之一步一步部署hadoop分布式集群
一.准备工作 同一个局域网中的三台linux虚拟机,我用的是redhat6.4,如果主机是windows操作系统,可以先安装vmware workstation, 然后在workstation中装上3 ...
- Hadoop学习笔记系列
Hadoop学习笔记系列 一.为何要学习Hadoop? 这是一个信息爆炸的时代.经过数十年的积累,很多企业都聚集了大量的数据.这些数据也是企业的核心财富之一,怎样从累积的数据里寻找价值,变废为宝炼 ...
- Hadoop学习笔记—22.Hadoop2.x环境搭建与配置
自从2015年花了2个多月时间把Hadoop1.x的学习教程学习了一遍,对Hadoop这个神奇的小象有了一个初步的了解,还对每次学习的内容进行了总结,也形成了我的一个博文系列<Hadoop学习笔 ...
- Hadoop学习笔记(9) ——源码初窥
Hadoop学习笔记(9) ——源码初窥 之前我们把Hadoop算是入了门,下载的源码,写了HelloWorld,简要分析了其编程要点,然后也编了个较复杂的示例.接下来其实就有两条路可走了,一条是继续 ...
- Hadoop学习笔记(6) ——重新认识Hadoop
Hadoop学习笔记(6) ——重新认识Hadoop 之前,我们把hadoop从下载包部署到编写了helloworld,看到了结果.现是得开始稍微更深入地了解hadoop了. Hadoop包含了两大功 ...
- Hadoop学习笔记(2)
Hadoop学习笔记(2) ——解读Hello World 上一章中,我们把hadoop下载.安装.运行起来,最后还执行了一个Hello world程序,看到了结果.现在我们就来解读一下这个Hello ...
- Hadoop学习笔记(5) ——编写HelloWorld(2)
Hadoop学习笔记(5) ——编写HelloWorld(2) 前面我们写了一个Hadoop程序,并让它跑起来了.但想想不对啊,Hadoop不是有两块功能么,DFS和MapReduce.没错,上一节我 ...
- Hadoop学习笔记(2) ——解读Hello World
Hadoop学习笔记(2) ——解读Hello World 上一章中,我们把hadoop下载.安装.运行起来,最后还执行了一个Hello world程序,看到了结果.现在我们就来解读一下这个Hello ...
- Hadoop学习笔记(1) ——菜鸟入门
Hadoop学习笔记(1) ——菜鸟入门 Hadoop是什么?先问一下百度吧: [百度百科]一个分布式系统基础架构,由Apache基金会所开发.用户可以在不了解分布式底层细节的情况下,开发分布式程序. ...
随机推荐
- 练习2 练习目标-使用引用类型的成员变量:在本练习中,将扩展银行项目,添加一个(客户类)Customer类。Customer类将包含一个Account对象。
package banking; public class Customer { private String firstName; private String lastName; private ...
- Python数据类型之“文本序列(Text Sequence)”
Python中的文本序列类型 Python中的文本数据由str对象或字符串进行处理. 1.字符串 字符串是Unicode码值的不可变序列.字符串字面量有多种形式: 单引号:'允许嵌入"双&q ...
- 关于Ubuntu运行级别、开机启动脚本的说明
关于Ubuntu运行级别.开机启动脚本的说明 目录简介 1.1介绍Ubuntu下面的自启动脚本目录 1.2 Linux操作系统运行级别的概念 1.3关于操作系统自启脚本的启动顺序 1.4 Lin ...
- sublime简要笔记
选中单词 [1]选中当前单词 ctrl+d [2]跳过当前单词 ctrl+k ctrl+d [3]选中相同的所有单词 alt+f3 [4]多行游标 按住shift,然后按住鼠标右键向下拖动 行操作 [ ...
- MyEclipse在搭建s2sh时 如何 uninstalled facet
在资源管理器中:找到当前[项目的根目录],在[.setting]目录中, 找到[org.eclipse.wst.common.project.facet.core.xml]文件. 用[文本编辑器工具] ...
- 如何用Python输出PPT中的文字信息
在这里,会用到win32com模块 模块下载地址:http://sourceforge.net/projects/pywin32/files/pywin32/ 代码如下: import win32co ...
- ”Connection reset by peer“引发的思考
闲来无事,把之前写的一个游戏服务器框架(<一个java页游服务器框架>),部署到阿里云服务器上,测试运行了下,结果看到后台log中打印出了“Connection reset by peer ...
- [New Portal]Windows Azure Virtual Machine (17) Virtual Machine成本分析
<Windows Azure Platform 系列文章目录> 在Windows Azure VM里,计费模式是和以下几个因素有关: 成本1: VM Type and VM Size 具体 ...
- 用Vue实现一个全选指令
最近用vue做了两个项目,都需要实现全选反选的功能,两个项目用了两种实现方法,第一个项目用vue的computed,第二个项目用指令来实现,用起来,发觉指令更加方便. 第一次做全选的时候是刚开始接触v ...
- Tornado框架
Tornado介绍 Tornado 是 FriendFeed 使用的可扩展的异步非阻塞式 web 服务器及其相关工具的开源版本.这个 Web 框架看起来有些像web.py(豆瓣用这个写的) 或者 Go ...