Ubuntu下搭建Hadoop伪分布式

一、在Ubuntu下创建hadoop组和hadoop用户

    增加Hadoop用户组,同时在该组里增加hadoop用户,后续在涉及到hadoop操作时,我们使用该用户。

 

1、创建hadoop用户组

 

        

 

 

 

    2、创建hadoop用户

    

    sudo adduser -ingroup hadoop hadoop

    回车后会提示输入新的UNIX密码,这是新建用户hadoop的密码,输入回车即可。

    如果不输入密码,回车后会重新提示输入密码,即密码不能为空。

    最后确认信息是否正确,如果没问题,输入 Y,回车即可。

    

 

 

 

 

 

 

 

 

 

 

 

 

    3、为hadoop用户添加权限

 

     输入:sudo gedit /etc/sudoers

     回车,打开sudoers文件

     给hadoop用户赋予和root用户同样的权限

 

 

    

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

二、用新增加的hadoop用户登录Ubuntu系统

 

三、安装ssh

sudo apt-get install openssh-server

 

 

 

 

 

 

 

 

 

 

 

 

安装完成后,启动服务

sudo /etc/init.d/ssh start

 

查看服务是否正确启动:ps -e | grep ssh

 

 

 

 

 

 

设置免密码登录,生成私钥和公钥

ssh-keygen -t rsa -P “”

 

 

 

 

 

 

 

 

 

 

 

 

 

此时会在/home/hadoop/.ssh下生成两个文件:id_rsa和id_rsa.pub,前者为私钥,后者为公钥。

下面我们将公钥追加到authorized_keys中,它用户保存所有允许以当前用户身份登录到ssh客户端用户的公钥内容。

cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys

 

 

 

登录ssh

ssh localhost

 

 

 

 

 

 

 

 

 

 

      

退出

exit

 

四、安装Java环境

提前注意:如果Ubuntu16版本可能提示找不到openjdk软件目录引用,因为软件仓库没有自带这个包,需要手动添加到仓库。如下: Ubuntu16.04的安装源已经默认没有openjdk7了,所以要自己手动添加仓库,如下: sudo add-apt-repository ppa:openjdk-r/ppa sudo apt-get update sudo apt-get install openjdk-7-jdk,如果是其他版本,则直接运行: sudo apt-get install openjdk-7-jdk

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

查看安装结果,输入命令:Java -version,结果如下表示安装成功。

 

 

 

 

五、安装hadoop2.4.0

    1、官网下载http://mirror.bit.edu.cn/apache/hadoop/common/

 

    2、安装

 

        解压

        sudo tar xzf hadoop-2.4.0.tar.gz        

        假如我们要把hadoop安装到/usr/local下

        拷贝到/usr/local/下,文件夹为hadoop

        sudo mv hadoop-2.4.0 /usr/local/hadoop        

        

 

赋予用户对该文件夹的读写权限

        sudo chmod 774 /usr/local/hadoop

    

 

3、配置

      

        1)配置~/.bashrc

        

配置该文件前需要知道Java的安装路径,用来设置JAVA_HOME环境变量,可以使用下面命令行查看安装路径

        update-alternatives - -config java

        执行结果如下:

        

    

 

 

 

完整的路径为

    /usr/lib/jvm/java-7-openjdk-amd64/jre/bin/java

    我们只取前面的部分 /usr/lib/jvm/java-7-openjdk-amd64

    配置.bashrc文件

    sudo gedit ~/.bashrc

    

    该命令会打开该文件的编辑窗口,在文件末尾追加下面内容,然后保存,关闭编辑窗口。

#HADOOP VARIABLES START

export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64

export HADOOP_INSTALL=/usr/local/hadoop

export PATH= PATH: HADOOP_INSTALL/bin

export PATH= PATH: HADOOP_INSTALL/sbin

export HADOOP_MAPRED_HOME=$HADOOP_INSTALL

export HADOOP_COMMON_HOME=$HADOOP_INSTALL

export HADOOP_HDFS_HOME=$HADOOP_INSTALL

export YARN_HOME=$HADOOP_INSTALL

export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_INSTALL/lib/native

export HADOOP_OPTS=”-Djava.library.path=$HADOOP_INSTALL/lib”

#HADOOP VARIABLES END

 

 

最终结果如下图:

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

执行下面命,使添加的环境变量生效:

        source ~/.bashrc

2)编辑/usr/local/hadoop/etc/hadoop/hadoop-env.sh

 

        执行下面命令,打开该文件的编辑窗口

        sudo gedit /usr/local/hadoop/etc/hadoop/hadoop-env.sh

找到JAVA_HOME变量,修改此变量如下

        export JAVA_HOME=/usr/lib/jvm/java-7-openjdk-amd64    

        修改后的hadoop-env.sh文件如下所示:

    

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

接下来就是hadoop2.x的几个核心配置文件,这里chidianwei-virtualbox是我的计算机名称,大家可以改为自己的即可。 具体如下:

  core-site.xml配置:       <property>
            <name>fs.defaultFS</name>
            <value>hdfs://chidianwei-VirtualBox:9000</value>
        </property>
        <!-- 指定hadoop运行时产生文件的存储目录 -->
        <property>
            <name>hadoop.tmp.dir</name>
            <value>/home/hadoop/hadoop/tmp</value>
           </property>

  hdfs-site.xml配置:

  <!-- 指定HDFS副本的数量 -->
        <property>
            <name>dfs.replication</name>
            <value>1</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上 -->

 yarn-site.xml配置
        <!-- 指定YARN的老大(ResourceManager)的地址 -->
     <property>
            <name>yarn.resourcemanager.hostname</name>
            <value>chidianwei-VirtualBox</value>
    </property>
        <!-- reducer获取数据的方式 -->
    <property>
            <name>yarn.nodemanager.aux-services</name>
            <value>mapreduce_shuffle</value>
     </property>
    <property><name>mapreduce.framework.name</name><value>yarn</value></property>
    slaves文件配置:
    这里需要注意,yarn的resourcemanager配置的服务器名称或者ip地址一定要和slaves对应。这里我配置的是hostname即本机名称,所以slaves需要加一行本机名称即可。如果rm是localhost则slaves文件也要是localhost,二者对应ip不一样。毕竟resourcemanager和slave机器(nodemanager)要通信。

六、WordCount测试

 

单机模式安装完成,下面通过执行hadoop自带实例WordCount验证是否安装成功

    /usr/local/hadoop路径下创建input文件夹    

mkdir input

 

    拷贝README.txt到input    

cp README.txt input

    执行WordCount

    bin/hadoop jar share/hadoop/mapreduce/sources/hadoop-mapreduce-examples-2.4.0-sources.jar org.apache.hadoop.examples.WordCount input output

    

 

 

执行结果:

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

执行 cat output/*,查看字符统计结果

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 常见问题:

问题: 50070 hadoop 打不开 50075可以打开

解决: hadoop namenode -format

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值