All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.hadoop.yarn.api.protocolrecords.FinishApplicationMasterRequest Maven / Gradle / Ivy

There is a newer version: 3.4.0
Show newest version
/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.hadoop.yarn.api.protocolrecords;

import org.apache.hadoop.classification.InterfaceAudience.Public;
import org.apache.hadoop.classification.InterfaceStability.Stable;
import org.apache.hadoop.yarn.api.ApplicationMasterProtocol;
import org.apache.hadoop.yarn.api.records.FinalApplicationStatus;
import org.apache.hadoop.yarn.util.Records;

/**
 * 

The finalization request sent by the ApplicationMaster to * inform the ResourceManager about its completion.

* *

The final request includes details such: *

    *
  • Final state of the ApplicationMaster
  • *
  • * Diagnostic information in case of failure of the * ApplicationMaster *
  • *
  • Tracking URL
  • *
*

* * @see ApplicationMasterProtocol#finishApplicationMaster(FinishApplicationMasterRequest) */ @Public @Stable public abstract class FinishApplicationMasterRequest { @Public @Stable public static FinishApplicationMasterRequest newInstance( FinalApplicationStatus finalAppStatus, String diagnostics, String url) { FinishApplicationMasterRequest request = Records.newRecord(FinishApplicationMasterRequest.class); request.setFinalApplicationStatus(finalAppStatus); request.setDiagnostics(diagnostics); request.setTrackingUrl(url); return request; } /** * Get final state of the ApplicationMaster. * @return final state of the ApplicationMaster */ @Public @Stable public abstract FinalApplicationStatus getFinalApplicationStatus(); /** * Set the final state of the ApplicationMaster * @param finalState final state of the ApplicationMaster */ @Public @Stable public abstract void setFinalApplicationStatus(FinalApplicationStatus finalState); /** * Get diagnostic information on application failure. * @return diagnostic information on application failure */ @Public @Stable public abstract String getDiagnostics(); /** * Set diagnostic information on application failure. * @param diagnostics diagnostic information on application failure */ @Public @Stable public abstract void setDiagnostics(String diagnostics); /** * Get the tracking URL for the ApplicationMaster. * This url if contains scheme then that will be used by resource manager * web application proxy otherwise it will default to http. * @return tracking URLfor the ApplicationMaster */ @Public @Stable public abstract String getTrackingUrl(); /** * Set the final tracking URLfor the ApplicationMaster. * This is the web-URL to which ResourceManager or web-application proxy will * redirect client/users once the application is finished and the * ApplicationMaster is gone. *

* If the passed url has a scheme then that will be used by the * ResourceManager and web-application proxy, otherwise the scheme will * default to http. *

*

* Empty, null, "N/A" strings are all valid besides a real URL. In case an url * isn't explicitly passed, it defaults to "N/A" on the ResourceManager. *

* * @param url * tracking URLfor the ApplicationMaster */ @Public @Stable public abstract void setTrackingUrl(String url); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy