【腾讯云的1001种玩法】在腾讯云上部署你的Hadoop集群

前言

Apache Hadoop软件库是一个框架,开发者只需使用简单的编程模型在大量计算机(配置不高)上对大型数据集进行分布式处理。

YingJoy

Hadoop有两种安装模式

  1. 完全分布式
  2. 伪分布式(单机)

本文采用完全分布式进行安装。

准备

master:      123.206.111.142      hadoop-master 
slave :       115.159.221.61        hadoop-slave-1
slave :       123.206.217.178      hadoop-slave-2

一、安装Java

执行下面代码

cd /opt/
wget --no-cookies --no-check-certificate --header "Cookie: gpw_e24=http%3A%2F%2Fwww.oracle.com%2F; oraclelicense=accept-securebackup-cookie" "http://download.oracle.com/otn-pub/java/jdk/7u79-b15/jdk-7u79-linux-x64.tar.gz"

tar xzf jdk-7u79-linux-x64.tar.gz

用alternatives安装Java

cd /opt/jdk1.7.0_79/
alternatives --install /usr/bin/java java /opt/jdk1.7.0_79/bin/java 2
alternatives --config java

你会看到这个

There are 3 programs which provide 'java'.

  Selection    Command
-----------------------------------------------
*  1           /opt/jdk1.7.0_60/bin/java
 + 2           /opt/jdk1.7.0_72/bin/java
   3           /opt/jdk1.7.0_79/bin/java

Enter to keep the current selection[+], or type selection number: 3 [Press Enter]

这里选择3

现在设置javac和jar命令

alternatives --install /usr/bin/jar jar /opt/jdk1.7.0_79/bin/jar 2
alternatives --install /usr/bin/javac javac /opt/jdk1.7.0_79/bin/javac 2
alternatives --set jar /opt/jdk1.7.0_79/bin/jar
alternatives --set javac /opt/jdk1.7.0_79/bin/javac

查看Java是否安装成功

java -version

java version "1.7.0_79"
Java(TM) SE Runtime Environment (build 1.7.0_79-b15)
Java HotSpot(TM) 64-Bit Server VM (build 24.79-b02, mixed mode)

配置环境变量

vi ~/.bashrc

在文件尾部加上下面的代码

export JAVA_HOME=/opt/jdk1.7.0_79
export JRE_HOME=/opt/jdk1.7.0_79/jre
export PATH=$PATH:/opt/jdk1.7.0_79/bin:/opt/jdk1.7.0_79/jre/bin

二、服务器创建Hadoop账号

执行下面代码

useradd hadoop
passwd hadoop

会看到下面

Changing password for user hadoop.
New password:
Retype new password:
passwd: all authentication tokens updated successfully.

三、修改/etc/hosts

执行下面代码

vi /etc/hosts

在文件下面增加下面三句

master的ip hadoop-master
slave1的ip hadoop-slave-1
slave2的ip hadoop-slave-2

四、设置机器之间ssh免密码登陆

仅在Hadoop用户下免密登陆,我听到很多人说配置后仍需密码,那是因为他们使用了root用户来连接。

su - hadoop
ssh-keygen -t rsa
ssh-copy-id -i ~/.ssh/id_rsa.pub hadoop@hadoop-master
ssh-copy-id -i ~/.ssh/id_rsa.pub hadoop@hadoop-slave-1
ssh-copy-id -i ~/.ssh/id_rsa.pub hadoop@hadoop-slave-2
chmod 0600 ~/.ssh/authorized_keys
exit

五、下载Hadoop

这里使用Hadoop的一个稳定点的版本2.7.3

mkdir /opt/hadoop
cd /opt/hadoop/
wget http://apache.mesi.com.ar/hadoop/common/hadoop-2.7.3/hadoop-2.7.3.tar.gz
tar -xzf hadoop-2.7.3.tar.gz
mv hadoop-2.7.3 hadoop
chown -R hadoop /opt/hadoop
cd /opt/hadoop/hadoop/

六、配置Hadoop

1.修改core-site.xml

在<configuration>标签中间添加下面内容

<property>
    <name>fs.default.name</name>
    <value>hdfs://hadoop-master:9000/</value>
</property>
<property>
    <name>dfs.permissions</name>
    <value>false</value>
</property>

2.修改hdfs-site.xml

在<configuration>标签中间添加下面内容

<property>
	<name>dfs.data.dir</name>
	<value>/opt/hadoop/hadoop/dfs/name/data</value>
	<final>true</final>
</property>
<property>
	<name>dfs.name.dir</name>
	<value>/opt/hadoop/hadoop/dfs/name</value>
	<final>true</final>
</property>
<property>
	<name>dfs.replication</name>
	<value>1</value>
</property>

3.修改 mapred-site.xml

首先先运行下面命令

cp mapred-site.xml.template mapred-site.xml

然后在<configuration>标签中间添加下面内容

<property>
        <name>mapred.job.tracker</name>
	<value>hadoop-master:9001</value>
</property>

4.修改hadoop-env.sh

export JAVA_HOME=/opt/jdk1.7.0_79
export HADOOP_OPTS=-Djava.net.preferIPv4Stack=true
export HADOOP_CONF_DIR=/opt/hadoop/hadoop/conf

你的Java路径

七、复制Hadoop到子节点

利用SSH复制,速度有点慢,喝杯茶等一下

su hadoop
cd /opt/hadoop
scp -r hadoop hadoop-slave-1:/opt/hadoop
scp -r hadoop hadoop-slave-2:/opt/hadoop

八、配置Hadoop(只在master上进行)

先进入Hadoop路径

su hadoop
cd /opt/hadoop/hadoop

1.修改conf/masters

hadoop-master

2.修改conf/slaves

hadoop-slave-1
hadoop-slave-2

九、在master上格式化namenode

su hadoop
cd /opt/hadoop/hadoop
bin/hadoop namenode -format

十、开启Hadoop服务

使用下面命令,直接启动所有服务

 bin/start-all.sh

相关推荐

基于OGG的Oracle与Hadoop集群准实时同步介绍

【腾讯云的1001种玩法】hadoop伪分布式搭建

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏java达人

Oracle 常用命令

1、启动oracle数据库: 从root切换到oracle用户进入: su - oracle 进入sqlplus环境,nolog参数表示不登录: sqlplus...

1917
来自专栏Hadoop实操

3.如何实现OpenLDAP的主主同步

前面Fayson文章讲《1.如何在CentOS6.5安装OpenLDAP并配置客户端》以及《2.OpenLDAP集成SSH登录并使用SSSD同步用户》,那么如何...

4185
来自专栏Hadoop实操

如何在CDH中配置YARN动态资源池的计划规则

在CDH中使用Yarn的动态资源池,用户会根据时段来区分集群资源的分配情况(如:在夜晚时段集群资源主要倾向于跑批作业,白天时段集群资源主要倾向于业务部门实时计算...

3855
来自专栏james大数据架构

如何开发自己的搜索帝国之Elasticsearch

搜索引擎是什么?   搜索引擎是指根据一定的策略、运用特定的计算机程序从互联网上搜集信息,在对信息进行组织和处理后,为用户提供检索服务,将用户检索相关的信息展示...

2067
来自专栏烂笔头

SSDB安装配置记录

目录[-] SSDB的性能很突出,与Redis基本相当了,Redis是内存型,容量问题是弱项,并且内存成本太高,SSDB针对这个弱点,使用硬盘存储,使用G...

3898
来自专栏我是攻城师

CDH-Hadoop2.6+ Apache Pig0.15安装记录

3375
来自专栏玩转JavaEE

Spring Cloud Bus整合Kafka

Kafka是由LinkedIn开发并开源的分布式消息系统,因其分布式及高吞吐率而被广泛使用,现已与Cloudera Hadoop,Apache Storm,Ap...

40410
来自专栏从零开始的linux

部署elk平台

说明 对于ELK部署使用而言,下面是一个再常见不过的架构了 Redis:接收用户日志的消息队列。 Logstash:做日志解析,统一成JSON输出给Elasti...

4333

将Java EE应用程序部署到Docker Swarm集群

Docker Swarm为Docker提供本地集群。 使用Docker Swarm 0.2.0的集群一文提供了对Docker Swarm的基本介绍,以及如何创建...

2869
来自专栏老安的博客

加速 cinder 删除volume速度

1093

扫码关注云+社区