真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

hadoop-ID的示例分析

小編給大家分享一下hadoop-ID的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

公司主營(yíng)業(yè)務(wù):成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)推出常山免費(fèi)做網(wǎng)站回饋大家。

我們開(kāi)始來(lái)分析Hadoop MapReduce的內(nèi)部的運(yùn)行機(jī)制。用戶向Hadoop提交Job(作業(yè)),作業(yè)在JobTracker對(duì)象的控制下執(zhí)行。Job被分解成為Task(任務(wù)),分發(fā)到集群中,在TaskTracker的控制下運(yùn)行。Task包括MapTask和ReduceTask,是MapReduce的Map操作和Reduce操作執(zhí)行的地方。這中任務(wù)分布的方法比較類似于HDFS中NameNode和DataNode的分工,NameNode對(duì)應(yīng)的是JobTracker,DataNode對(duì)應(yīng)的是TaskTracker。JobTracker,TaskTracker和MapReduce的客戶端通過(guò)RPC通信,具體可以參考HDFS部分的分析。

我們先來(lái)分析一些輔助類,首先是和ID有關(guān)的類,ID的繼承樹(shù)如下:

hadoop-ID的示例分析
 

* Licensed to the Apache Software Foundation (ASF) under one

package org.apache.hadoop.mapreduce;

import java.io.DataInput;

/**
 * A general identifier, which internally stores the id
 * as an integer. This is the super class of {@link JobID}, 
 * {@link TaskID} and {@link TaskAttemptID}.
 * 
 * @see JobID
 * @see TaskID
 * @see TaskAttemptID
 */
public abstract class ID implements WritableComparable {
  protected static final char SEPARATOR = '_';
  protected int id;

  /** constructs an ID object from the given int */
  public ID(int id) {
    this.id = id;
  }

  protected ID() {
  }

  /** returns the int which represents the identifier */
  public int getId() {
    return id;
  }

  @Override
  public String toString() {
    return String.valueOf(id);
  }

  @Override
  public int hashCode() {
    return Integer.valueOf(id).hashCode();
  }

  @Override
  public boolean equals(Object o) {
    if (this == o)
      return true;
    if(o == null)
      return false;
    if (o.getClass() == this.getClass()) {
      ID that = (ID) o;
      return this.id == that.id;
    }
    else
      return false;
  }

  /** Compare IDs by associated numbers */
  public int compareTo(ID that) {
    return this.id - that.id;
  }

  public void readFields(DataInput in) throws IOException {
    this.id = in.readInt();
  }

  public void write(DataOutput out) throws IOException {
    out.writeInt(id);
  }
  
}
* Licensed to the Apache Software Foundation (ASF) under one

package org.apache.hadoop.mapreduce;

import java.io.DataInput;

/**
 * JobID represents the immutable and unique identifier for 
 * the job. JobID consists of two parts. First part 
 * represents the jobtracker identifier, so that jobID to jobtracker map 
 * is defined. For cluster setup this string is the jobtracker 
 * start time, for local setting, it is "local".
 * Second part of the JobID is the job number. 
   * An example JobID is :   * job_200707121733_0003 , which represents the third job   * running at the jobtracker started at 200707121733.   * 

 * Applications should never construct or parse JobID strings, but rather   * use appropriate constructors or {@link #forName(String)} method.   *   * @see TaskID  * @see TaskAttemptID  * @see org.apache.hadoop.mapred.JobTracker#getNewJobId()  * @see org.apache.hadoop.mapred.JobTracker#getStartTime()  */ public class JobID extends org.apache.hadoop.mapred.ID                     implements Comparable {   protected static final String JOB = "job";   private final Text jtIdentifier;      protected static final NumberFormat idFormat = NumberFormat.getInstance();   static {     idFormat.setGroupingUsed(false);     idFormat.setMinimumIntegerDigits(4);   }      /**    * Constructs a JobID object     * @param jtIdentifier jobTracker identifier    * @param id job number    */   public JobID(String jtIdentifier, int id) {     super(id);     this.jtIdentifier = new Text(jtIdentifier);   }      public JobID() {      jtIdentifier = new Text();   }      public String getJtIdentifier() {     return jtIdentifier.toString();   }      @Override   public boolean equals(Object o) {     if (!super.equals(o))       return false;     JobID that = (JobID)o;     return this.jtIdentifier.equals(that.jtIdentifier);   }      /**Compare JobIds by first jtIdentifiers, then by job numbers*/   @Override   public int compareTo(ID o) {     JobID that = (JobID)o;     int jtComp = this.jtIdentifier.compareTo(that.jtIdentifier);     if(jtComp == 0) {       return this.id - that.id;     }     else return jtComp;   }      /**    * Add the stuff after the "job" prefix to the given builder. This is useful,    * because the sub-ids use this substring at the start of their string.    * @param builder the builder to append to    * @return the builder that was passed in    */   public StringBuilder appendTo(StringBuilder builder) {     builder.append(SEPARATOR);     builder.append(jtIdentifier);     builder.append(SEPARATOR);     builder.append(idFormat.format(id));     return builder;   }   @Override   public int hashCode() {     return jtIdentifier.hashCode() + id;   }   @Override   public String toString() {     return appendTo(new StringBuilder(JOB)).toString();   }   @Override   public void readFields(DataInput in) throws IOException {     super.readFields(in);     this.jtIdentifier.readFields(in);   }   @Override   public void write(DataOutput out) throws IOException {     super.write(out);     jtIdentifier.write(out);   }      /** Construct a JobId object from given string     * @return constructed JobId object or null if the given String is null    * @throws IllegalArgumentException if the given string is malformed    */   public static JobID forName(String str) throws IllegalArgumentException {     if(str == null)       return null;     try {       String[] parts = str.split("_");       if(parts.length == 3) {         if(parts[0].equals(JOB)) {           return new org.apache.hadoop.mapred.JobID(parts[1],                                                      Integer.parseInt(parts[2]));         }       }     }catch (Exception ex) {//fall below     }     throw new IllegalArgumentException("JobId string : " + str          + " is not properly formed");   }    }

以上是“hadoop-ID的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


新聞名稱:hadoop-ID的示例分析
URL標(biāo)題:http://weahome.cn/article/jgdogs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部