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

org.apache.hadoop.yarn.client.api.AppAdminClient Maven / Gradle / Ivy

The 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.client.api; import org.apache.hadoop.classification.InterfaceAudience.Private; import org.apache.hadoop.classification.InterfaceAudience.Public; import org.apache.hadoop.classification.InterfaceStability.Unstable; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.service.CompositeService; import org.apache.hadoop.util.ReflectionUtils; import org.apache.hadoop.yarn.exceptions.YarnException; import org.apache.hadoop.yarn.exceptions.YarnRuntimeException; import java.io.File; import java.io.IOException; import java.util.List; import java.util.Map; /** * Client for managing applications. */ @Public @Unstable public abstract class AppAdminClient extends CompositeService { public static final String YARN_APP_ADMIN_CLIENT_PREFIX = "yarn" + ".application.admin.client.class."; public static final String DEFAULT_TYPE = "yarn-service"; public static final String DEFAULT_CLASS_NAME = "org.apache.hadoop.yarn" + ".service.client.ApiServiceClient"; public static final String UNIT_TEST_TYPE = "unit-test"; public static final String UNIT_TEST_CLASS_NAME = "org.apache.hadoop.yarn" + ".service.client.ServiceClient"; @Private protected AppAdminClient() { super(AppAdminClient.class.getName()); } /** *

* Create a new instance of AppAdminClient. *

* * @param appType application type * @param conf configuration * @return app admin client */ @Public @Unstable public static AppAdminClient createAppAdminClient(String appType, Configuration conf) { Map clientClassMap = conf.getPropsWithPrefix(YARN_APP_ADMIN_CLIENT_PREFIX); if (!clientClassMap.containsKey(DEFAULT_TYPE)) { clientClassMap.put(DEFAULT_TYPE, DEFAULT_CLASS_NAME); } if (!clientClassMap.containsKey(UNIT_TEST_TYPE)) { clientClassMap.put(UNIT_TEST_TYPE, UNIT_TEST_CLASS_NAME); } if (!clientClassMap.containsKey(appType)) { throw new IllegalArgumentException("App admin client class name not " + "specified for type " + appType + ". Please ensure " + appType + " framework has provided a client implementation to handle" + " this functionality."); } String clientClassName = clientClassMap.get(appType); Class clientClass; try { clientClass = (Class) Class.forName( clientClassName); } catch (ClassNotFoundException e) { throw new YarnRuntimeException("Invalid app admin client class", e); } AppAdminClient appAdminClient = ReflectionUtils.newInstance(clientClass, conf); appAdminClient.init(conf); appAdminClient.start(); return appAdminClient; } /** *

* Launch a new YARN application. *

* * @param fileName specification of application * @param appName name of the application * @param lifetime lifetime of the application * @param queue queue of the application * @return exit code * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract int actionLaunch(String fileName, String appName, Long lifetime, String queue) throws IOException, YarnException; /** *

* Stop a YARN application (attempt to stop gracefully before killing the * application). In the case of a long-running service, the service may be * restarted later. *

* * @param appName the name of the application * @return exit code * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract int actionStop(String appName) throws IOException, YarnException; /** *

* Start a YARN application from a previously saved specification. In the * case of a long-running service, the service must have been previously * launched/started and then stopped, or previously saved but not started. *

* * @param appName the name of the application * @return exit code * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract int actionStart(String appName) throws IOException, YarnException; /** *

* Save the specification for a YARN application / long-running service. * The application may be started later. *

* * @param fileName specification of application to save * @param appName name of the application * @param lifetime lifetime of the application * @param queue queue of the application * @return exit code * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract int actionSave(String fileName, String appName, Long lifetime, String queue) throws IOException, YarnException; /** *

* Remove the specification and all application data for a YARN application. * The application cannot be running. *

* * @param appName the name of the application * @return exit code * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract int actionDestroy(String appName) throws IOException, YarnException; /** *

* Change the number of running containers for a component of a YARN * application / long-running service. *

* * @param appName the name of the application * @param componentCounts map of component name to new component count or * amount to change existing component count (e.g. * 5, +5, -5) * @return exit code * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract int actionFlex(String appName, Map componentCounts) throws IOException, YarnException; /** *

* Upload AM dependencies to HDFS. This makes future application launches * faster since the dependencies do not have to be uploaded on each launch. *

* * @param destinationFolder * an optional HDFS folder where dependency tarball will be uploaded * @return exit code * @throws IOException * IOException * @throws YarnException * exception in client or server */ @Public @Unstable public abstract int enableFastLaunch(String destinationFolder) throws IOException, YarnException; /** *

* Get detailed app specific status string for a YARN application. *

* * @param appIdOrName appId or appName * @return status string * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract String getStatusString(String appIdOrName) throws IOException, YarnException; /** * Initiate upgrade of a long running service. * * @param appName the name of the application. * @param fileName specification of application upgrade to save. * @param autoFinalize when true, finalization of upgrade will be done * automatically. * @return exit code * @throws IOException IOException * @throws YarnException exception in client or server */ @Public @Unstable public abstract int initiateUpgrade(String appName, String fileName, boolean autoFinalize) throws IOException, YarnException; /** * Upgrade component instances of a long running service. * * @param appName the name of the application. * @param componentInstances the name of the component instances. * @return exit code. * @throws IOException io error occur. * @throws YarnException exceptions from yarn servers. */ @Public @Unstable public abstract int actionUpgradeInstances(String appName, List componentInstances) throws IOException, YarnException; /** * Upgrade components of a long running service. * * @param appName the name of the application. * @param components the name of the components. * @return exit code. * @throws IOException io error occur. * @throws YarnException exceptions from yarn servers. */ @Public @Unstable public abstract int actionUpgradeComponents(String appName, List components) throws IOException, YarnException; /** * Operation to be performed by the RM after an application has completed. * * @param appName the name of the application. * @param userName the name of the user. * @return exit code * @throws IOException io error occur. * @throws YarnException exceptions from yarn servers. * @throws InterruptedException if interrupted. */ @Public @Unstable public abstract int actionCleanUp(String appName, String userName) throws IOException, YarnException, InterruptedException; @Public @Unstable public abstract String getInstances(String appName, List components, String version, List containerStates) throws IOException, YarnException; /** * Express upgrade a long running service. * * @param appName the name of the application * @param fileName specification of application upgrade to save. * @return exit code * @throws IOException io error occur. * @throws YarnException exceptions from yarn servers. */ @Public @Unstable public abstract int actionUpgradeExpress(String appName, File fileName) throws IOException, YarnException; /** * Cancels the upgrade of the service. * * @param appName the name of the application * @return exit code * @throws IOException io error occur. * @throws YarnException exceptions from yarn servers. */ @Public @Unstable public abstract int actionCancelUpgrade(String appName) throws IOException, YarnException; /** * Decommission component instances of a long running service. * * @param appName the name of the application. * @param componentInstances the name of the component instances. * @throws IOException io error occur. * @throws YarnException exceptions from yarn servers. * @return exit code. */ @Public @Unstable public abstract int actionDecommissionInstances(String appName, List componentInstances) throws IOException, YarnException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy