zoukankan      html  css  js  c++  java
  • Hadoop单机部署方法

     

    安装Java JDK:

    到sun网站上下载jdk

    chmod +x jdk-6u30-linux-x64.bin

    ./jdk-6u30-linux-x64.bin

     

    下载Hadoop

    wget http://labs.renren.com/apache-mirror/hadoop/common/hadoop-0.20.205.0/hadoop-0.20.205.0.tar.gz

    tar zxvf hadoop-0.20.205.0.tar.gz

     

    安装必要软件

    yum install ssh rsync

     

    修改配置文件

    conf/core-site.xml:

    <configuration>

    <property>

    <name>fs.default.name</name>

    <value>hdfs://localhost:9000</value>

    </property>

    </configuration>


    conf/hdfs-site.xml:

    <configuration>

    <property>

    <name>dfs.replication</name>

    <value>1</value>

    </property>

    </configuration>


    conf/mapred-site.xml:

    <configuration>

    <property>

    <name>mapred.job.tracker</name>

    <value>localhost:9001</value>

    </property>

    </configuration>

     

    conf/ hadoop-env.sh

    export JAVA_HOME=/root/jdk1.6.0_30

     

    bin/hadoop

    以root用户运行会报-jvm参数不存在的错误,故将

    if [[ $EUID -eq 0 ]]; then

    HADOOP_OPTS="$HADOOP_OPTS -jvm server $HADOOP_DATANODE_OPTS"

    else

    HADOOP_OPTS="$HADOOP_OPTS -server $HADOOP_DATANODE_OPTS"

    fi

    修改为

    elif [ "$COMMAND" = "datanode" ] ; then

    CLASS='org.apache.hadoop.hdfs.server.datanode.DataNode'

    HADOOP_OPTS="$HADOOP_OPTS -server $HADOOP_DATANODE_OPTS"

     

    SSH设置

    $ ssh-keygen -t dsa -P '' -f ~/.ssh/id_dsa 
    $ cat ~/.ssh/id_dsa.pub >> ~/.ssh/authorized_keys

     

    启动hadoop

    $ bin/hadoop namenode -format
    $ bin/start-all.sh

     

    此时,通过本地的50070和50030端口就可以分别浏览到NameNode和JobTracker:

    • JobTracker - http://localhost:50030/

       

       

      测试wordcount

      生成测试数据:

      [root hadoop-0.20.205.0]# mkdir input

      [root hadoop-0.20.205.0]# echo "hello world" >> input/a.txt

      [root hadoop-0.20.205.0]# echo "hello hadoop" >> input/b.txt

      将本地数据复制到HDFS中:

      [root hadoop-0.20.205.0]# bin/hadoop fs -put input in

      执行测试任务:

      [root hadoop-0.20.205.0]# bin/hadoop jar hadoop-examples-0.20.205.0.jar wordcount in out

      12/02/05 21:00:47 INFO input.FileInputFormat: Total input paths to process : 2

      12/02/05 21:00:48 INFO mapred.JobClient: Running job: job_201202052055_0001

      12/02/05 21:00:49 INFO mapred.JobClient: map 0% reduce 0%

      12/02/05 21:01:07 INFO mapred.JobClient: map 100% reduce 0%

      12/02/05 21:01:19 INFO mapred.JobClient: map 100% reduce 100%

      12/02/05 21:01:24 INFO mapred.JobClient: Job complete: job_201202052055_0001

      12/02/05 21:01:24 INFO mapred.JobClient: Counters: 29

      12/02/05 21:01:24 INFO mapred.JobClient: Job Counters

      12/02/05 21:01:24 INFO mapred.JobClient: Launched reduce tasks=1

      12/02/05 21:01:24 INFO mapred.JobClient: SLOTS_MILLIS_MAPS=22356

      12/02/05 21:01:24 INFO mapred.JobClient: Total time spent by all reduces waiting after reserving slots (ms)=0

      12/02/05 21:01:24 INFO mapred.JobClient: Total time spent by all maps waiting after reserving slots (ms)=0

      12/02/05 21:01:24 INFO mapred.JobClient: Launched map tasks=2

      12/02/05 21:01:24 INFO mapred.JobClient: Data-local map tasks=2

      12/02/05 21:01:24 INFO mapred.JobClient: SLOTS_MILLIS_REDUCES=10801

      12/02/05 21:01:24 INFO mapred.JobClient: File Output Format Counters

      12/02/05 21:01:24 INFO mapred.JobClient: Bytes Written=25

      12/02/05 21:01:24 INFO mapred.JobClient: FileSystemCounters

      12/02/05 21:01:24 INFO mapred.JobClient: FILE_BYTES_READ=55

      12/02/05 21:01:24 INFO mapred.JobClient: HDFS_BYTES_READ=235

      12/02/05 21:01:24 INFO mapred.JobClient: FILE_BYTES_WRITTEN=64345

      12/02/05 21:01:24 INFO mapred.JobClient: HDFS_BYTES_WRITTEN=25

      12/02/05 21:01:24 INFO mapred.JobClient: File Input Format Counters

      12/02/05 21:01:24 INFO mapred.JobClient: Bytes Read=25

      12/02/05 21:01:24 INFO mapred.JobClient: Map-Reduce Framework

      12/02/05 21:01:24 INFO mapred.JobClient: Map output materialized bytes=61

      12/02/05 21:01:24 INFO mapred.JobClient: Map input records=2

      12/02/05 21:01:24 INFO mapred.JobClient: Reduce shuffle bytes=61

      12/02/05 21:01:24 INFO mapred.JobClient: Spilled Records=8

      12/02/05 21:01:24 INFO mapred.JobClient: Map output bytes=41

      12/02/05 21:01:24 INFO mapred.JobClient: CPU time spent (ms)=2900

      12/02/05 21:01:24 INFO mapred.JobClient: Total committed heap usage (bytes)=398852096

      12/02/05 21:01:24 INFO mapred.JobClient: Combine input records=4

      12/02/05 21:01:24 INFO mapred.JobClient: SPLIT_RAW_BYTES=210

      12/02/05 21:01:24 INFO mapred.JobClient: Reduce input records=4

      12/02/05 21:01:24 INFO mapred.JobClient: Reduce input groups=3

      12/02/05 21:01:24 INFO mapred.JobClient: Combine output records=4

      12/02/05 21:01:24 INFO mapred.JobClient: Physical memory (bytes) snapshot=422445056

      12/02/05 21:01:24 INFO mapred.JobClient: Reduce output records=3

      12/02/05 21:01:24 INFO mapred.JobClient: Virtual memory (bytes) snapshot=1544007680

      12/02/05 21:01:24 INFO mapred.JobClient: Map output records=4

      查看结果:

      [root hadoop-0.20.205.0]# bin/hadoop fs -cat out/*

      hadoop    1

      hello    2

      world    1

      cat: File does not exist: /user/root/out/_logs

      将结果从HDFS复制到本地并查看:

      [root hadoop-0.20.205.0]# bin/hadoop fs -get out output

      [root hadoop-0.20.205.0]# cat output/*

      cat: output/_logs: Is a directory

      hadoop    1

      hello    2

      world    1

       

      此时,从JobTracker网页中也可以看到任务的执行情况:

  • 相关阅读:
    教你在mac上配置adb环境变量
    Android Mediaplayer 调用release()的时候ANR
    Android ANR
    安卓android WebView Memory Leak WebView内存泄漏
    android 小结
    struts提供文件上传功能
    struts自定义拦截器
    struts拦截器的配置和使用
    Struts框架属性驱动
    struts配置文件
  • 原文地址:https://www.cnblogs.com/feisky/p/2339311.html
Copyright © 2011-2022 走看看