YARN-6115. Few additional paths in Slider client still uses get all Applications without tags/states filter. Contributed by Gour Saha
This commit is contained in:
parent
a5e20f0fc1
commit
7edc154e0e
|
@ -142,7 +142,6 @@ import org.apache.slider.core.launch.ClasspathConstructor;
|
||||||
import org.apache.slider.core.launch.CredentialUtils;
|
import org.apache.slider.core.launch.CredentialUtils;
|
||||||
import org.apache.slider.core.launch.JavaCommandLineBuilder;
|
import org.apache.slider.core.launch.JavaCommandLineBuilder;
|
||||||
import org.apache.slider.core.launch.LaunchedApplication;
|
import org.apache.slider.core.launch.LaunchedApplication;
|
||||||
import org.apache.slider.core.launch.RunningApplication;
|
|
||||||
import org.apache.slider.core.launch.SerializedApplicationReport;
|
import org.apache.slider.core.launch.SerializedApplicationReport;
|
||||||
import org.apache.slider.core.main.RunService;
|
import org.apache.slider.core.main.RunService;
|
||||||
import org.apache.slider.core.persist.AppDefinitionPersister;
|
import org.apache.slider.core.persist.AppDefinitionPersister;
|
||||||
|
@ -1535,7 +1534,9 @@ public class SliderClient extends AbstractSliderLaunchedService implements RunSe
|
||||||
|
|
||||||
public void updateLifetime(String appName, long lifetime)
|
public void updateLifetime(String appName, long lifetime)
|
||||||
throws YarnException, IOException {
|
throws YarnException, IOException {
|
||||||
ApplicationReport report = findInstance(appName);
|
EnumSet<YarnApplicationState> appStates = EnumSet.range(
|
||||||
|
YarnApplicationState.NEW, YarnApplicationState.RUNNING);
|
||||||
|
ApplicationReport report = findInstance(appName, appStates);
|
||||||
if (report == null) {
|
if (report == null) {
|
||||||
throw new YarnException("Application not found for " + appName);
|
throw new YarnException("Application not found for " + appName);
|
||||||
}
|
}
|
||||||
|
@ -2672,15 +2673,17 @@ public class SliderClient extends AbstractSliderLaunchedService implements RunSe
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* List Slider instances belonging to a specific user. This will include
|
* List Slider instances belonging to a specific user with a specific app
|
||||||
* failed and killed instances; there may be duplicates
|
* name and within a set of app states.
|
||||||
* @param user user: "" means all users, null means "default"
|
* @param user user: "" means all users, null means "default"
|
||||||
|
* @param appName name of the application set as a tag
|
||||||
|
* @param appStates a set of states the applications should be in
|
||||||
* @return a possibly empty list of Slider AMs
|
* @return a possibly empty list of Slider AMs
|
||||||
*/
|
*/
|
||||||
|
public List<ApplicationReport> listSliderInstances(String user,
|
||||||
public List<ApplicationReport> listSliderInstances(String user)
|
String appName, EnumSet<YarnApplicationState> appStates)
|
||||||
throws YarnException, IOException {
|
throws YarnException, IOException {
|
||||||
return yarnAppListClient.listInstances(user);
|
return yarnAppListClient.listInstances(user, appName, appStates);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2806,7 +2809,9 @@ public class SliderClient extends AbstractSliderLaunchedService implements RunSe
|
||||||
}
|
}
|
||||||
|
|
||||||
// and those the RM knows about
|
// and those the RM knows about
|
||||||
List<ApplicationReport> instances = listSliderInstances(null);
|
EnumSet<YarnApplicationState> appStates = EnumSet.range(min, max);
|
||||||
|
List<ApplicationReport> instances = listSliderInstances(null, clustername,
|
||||||
|
appStates);
|
||||||
sortApplicationsByMostRecent(instances);
|
sortApplicationsByMostRecent(instances);
|
||||||
Map<String, ApplicationReport> reportMap =
|
Map<String, ApplicationReport> reportMap =
|
||||||
buildApplicationReportMap(instances, min, max);
|
buildApplicationReportMap(instances, min, max);
|
||||||
|
@ -3053,7 +3058,7 @@ public class SliderClient extends AbstractSliderLaunchedService implements RunSe
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find an instance of an application belonging to the current user
|
* Find an instance of an application belonging to the current user.
|
||||||
* @param appname application name
|
* @param appname application name
|
||||||
* @return the app report or null if none is found
|
* @return the app report or null if none is found
|
||||||
* @throws YarnException YARN issues
|
* @throws YarnException YARN issues
|
||||||
|
@ -3061,14 +3066,22 @@ public class SliderClient extends AbstractSliderLaunchedService implements RunSe
|
||||||
*/
|
*/
|
||||||
public ApplicationReport findInstance(String appname)
|
public ApplicationReport findInstance(String appname)
|
||||||
throws YarnException, IOException {
|
throws YarnException, IOException {
|
||||||
return yarnAppListClient.findInstance(appname);
|
return findInstance(appname, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
private RunningApplication findApplication(String appname)
|
/**
|
||||||
|
* Find an instance of an application belonging to the current user and in
|
||||||
|
* specific app states.
|
||||||
|
* @param appname application name
|
||||||
|
* @param appStates app states in which the application should be in
|
||||||
|
* @return the app report or null if none is found
|
||||||
|
* @throws YarnException YARN issues
|
||||||
|
* @throws IOException IO problems
|
||||||
|
*/
|
||||||
|
public ApplicationReport findInstance(String appname,
|
||||||
|
EnumSet<YarnApplicationState> appStates)
|
||||||
throws YarnException, IOException {
|
throws YarnException, IOException {
|
||||||
ApplicationReport applicationReport = findInstance(appname);
|
return yarnAppListClient.findInstance(appname, appStates);
|
||||||
return applicationReport != null ?
|
|
||||||
new RunningApplication(yarnClient, applicationReport): null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -32,6 +32,7 @@ import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -77,7 +78,7 @@ public class YarnAppListClient {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find an instance of a application belong to the current user
|
* Find an instance of a application belong to the current user.
|
||||||
* @param appname application name
|
* @param appname application name
|
||||||
* @return the app report or null if none is found
|
* @return the app report or null if none is found
|
||||||
* @throws YarnException YARN issues
|
* @throws YarnException YARN issues
|
||||||
|
@ -86,7 +87,22 @@ public class YarnAppListClient {
|
||||||
public ApplicationReport findInstance(String appname) throws
|
public ApplicationReport findInstance(String appname) throws
|
||||||
YarnException,
|
YarnException,
|
||||||
IOException {
|
IOException {
|
||||||
List<ApplicationReport> instances = listInstances(null, appname);
|
return findInstance(appname, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find an instance of a application belong to the current user in specific
|
||||||
|
* app states.
|
||||||
|
* @param appname application name
|
||||||
|
* @param appStates list of states in which application should be in
|
||||||
|
* @return the app report or null if none is found
|
||||||
|
* @throws YarnException YARN issues
|
||||||
|
* @throws IOException IO problems
|
||||||
|
*/
|
||||||
|
public ApplicationReport findInstance(String appname,
|
||||||
|
EnumSet<YarnApplicationState> appStates)
|
||||||
|
throws YarnException, IOException {
|
||||||
|
List<ApplicationReport> instances = listInstances(null, appname, appStates);
|
||||||
return yarnClient.findClusterInInstanceList(instances, appname);
|
return yarnClient.findClusterInInstanceList(instances, appname);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,21 +127,44 @@ public class YarnAppListClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* List all instances belonging to a specific user and a specific appname.
|
* List all instances belonging to a specific user with a specific app name.
|
||||||
*
|
*
|
||||||
* @param user
|
* @param user
|
||||||
* user if not the default. null means default, "" means all users,
|
* user if not the default. null means default, "" means all users,
|
||||||
* otherwise it is the name of a user
|
* otherwise it is the name of a user
|
||||||
* @param appname
|
* @param appName
|
||||||
* application name set as an application tag
|
* application name set as an application tag
|
||||||
* @return a possibly empty list of AMs
|
* @return a possibly empty list of AMs
|
||||||
* @throws YarnException
|
* @throws YarnException
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public List<ApplicationReport> listInstances(String user, String appname)
|
public List<ApplicationReport> listInstances(String user, String appName)
|
||||||
throws YarnException, IOException {
|
throws YarnException, IOException {
|
||||||
|
return listInstances(user, appName, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List all instances belonging to a specific user, with a specific app name
|
||||||
|
* and in specific app states.
|
||||||
|
*
|
||||||
|
* @param user
|
||||||
|
* user if not the default. null means default, "" means all users,
|
||||||
|
* otherwise it is the name of a user
|
||||||
|
* @param appName
|
||||||
|
* application name set as an application tag
|
||||||
|
* @param appStates
|
||||||
|
* a set of application states within which the app should be in
|
||||||
|
* @return a possibly empty list of AMs
|
||||||
|
* @throws YarnException
|
||||||
|
* @throws IOException
|
||||||
|
*/
|
||||||
|
public List<ApplicationReport> listInstances(String user, String appName,
|
||||||
|
EnumSet<YarnApplicationState> appStates)
|
||||||
|
throws YarnException, IOException {
|
||||||
|
log.debug("listInstances called with user: {}, appName: {}, appStates: {}",
|
||||||
|
user, appName, appStates);
|
||||||
String listUser = user == null ? username : user;
|
String listUser = user == null ? username : user;
|
||||||
return yarnClient.listDeployedInstances(listUser, null, appname);
|
return yarnClient.listDeployedInstances(listUser, appStates, appName);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue