Archives of Support Questions (Read Only)

This is an archived board for historical reference. Information and links may no longer be available or relevant
Announcements
This board is archived and read-only for historical reference. To ask a new question, please post a new topic on the appropriate active board.

Yarn: Application Id - How is it generated ?

avatar

I want to understand how the applicationId is generated when a job is submitted to Yarn.

1 ACCEPTED SOLUTION

avatar
Master Mentor

@Dinesh Chitlangia

Following code might give the idea on what you are looking out for:

https://github.com/apache/hadoop/blob/release-2.8.0-RC0/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-...

/**
 * <p><code>ApplicationId</code> represents the <em>globally unique</em> 
 * identifier for an application.</p>
 * 
 * <p>The globally unique nature of the identifier is achieved by using the 
 * <em>cluster timestamp</em> i.e. start-time of the 
 * <code>ResourceManager</code> along with a monotonically increasing counter
 * for the application.</p>
 */

  @Public
  @Unstable
  public static ApplicationId newInstance(long clusterTimestamp, int id) {
    ApplicationId appId = Records.newRecord(ApplicationId.class);
    appId.setClusterTimestamp(clusterTimestamp);
    appId.setId(id);
    appId.build();
    return appId;
  }

.

According to the API, The ApplicationId represents the globally unique identifier for an application. The globally unique nature of the identifier is achieved by using the "cluster timestamp" i.e. The start-time of the "ResourceManager<"/code>" along with a monotonically increasing counter for the application.

https://github.com/apache/hadoop/blob/release-2.8.0-RC0/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-...

.

View solution in original post

4 REPLIES 4

avatar

Application IDs are provided by Resource Manager to the client through the ApplicationSubmissionContext. More information can be found here:

https://hadoop.apache.org/docs/r2.7.2/hadoop-yarn/hadoop-yarn-site/WritingYarnApplications.html

avatar

Thank you Deepesh.

avatar
Master Mentor

@Dinesh Chitlangia

Following code might give the idea on what you are looking out for:

https://github.com/apache/hadoop/blob/release-2.8.0-RC0/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-...

/**
 * <p><code>ApplicationId</code> represents the <em>globally unique</em> 
 * identifier for an application.</p>
 * 
 * <p>The globally unique nature of the identifier is achieved by using the 
 * <em>cluster timestamp</em> i.e. start-time of the 
 * <code>ResourceManager</code> along with a monotonically increasing counter
 * for the application.</p>
 */

  @Public
  @Unstable
  public static ApplicationId newInstance(long clusterTimestamp, int id) {
    ApplicationId appId = Records.newRecord(ApplicationId.class);
    appId.setClusterTimestamp(clusterTimestamp);
    appId.setId(id);
    appId.build();
    return appId;
  }

.

According to the API, The ApplicationId represents the globally unique identifier for an application. The globally unique nature of the identifier is achieved by using the "cluster timestamp" i.e. The start-time of the "ResourceManager<"/code>" along with a monotonically increasing counter for the application.

https://github.com/apache/hadoop/blob/release-2.8.0-RC0/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-...

.

avatar

Perfect. Thank you.