YARN-11053. AuxService should not use class name as default system classes (#3816)

Signed-off-by: Akira Ajisaka <aajisaka@apache.org>
(cherry picked from commit 4db27acf06cb8526e3aa84a18904baa7ddd2c7c8)
This commit is contained in:
Cheng Pan 2021-12-24 10:08:04 +08:00 committed by Akira Ajisaka
parent 6c252cfb44
commit 7b51e6824d

View File

@ -240,7 +240,7 @@ public class AuxServices extends AbstractService
}
return AuxiliaryServiceWithCustomClassLoader.getInstance(conf, className,
appLocalClassPath, getSystemClasses(service, className));
appLocalClassPath, getSystemClasses(service));
}
/**
@ -292,7 +292,7 @@ public class AuxServices extends AbstractService
+ " is using the custom classloader with classpath " + destFiles);
return AuxiliaryServiceWithCustomClassLoader.getInstance(conf,
className, StringUtils.join(File.pathSeparatorChar, destFiles),
getSystemClasses(service, className));
getSystemClasses(service));
} else {
return createAuxServiceFromConfiguration(service);
}
@ -681,15 +681,12 @@ public class AuxServices extends AbstractService
return serviceConf.getProperty(CLASS_NAME);
}
private static String[] getSystemClasses(AuxServiceRecord service, String
className) {
AuxServiceConfiguration serviceConf =
service.getConfiguration();
if (serviceConf == null) {
return new String[]{className};
private static String[] getSystemClasses(AuxServiceRecord service) {
AuxServiceConfiguration serviceConf = service.getConfiguration();
if (serviceConf == null || serviceConf.getProperty(SYSTEM_CLASSES) == null) {
return new String[]{};
}
return StringUtils.split(serviceConf.getProperty(SYSTEM_CLASSES,
className));
return StringUtils.split(serviceConf.getProperty(SYSTEM_CLASSES));
}
/**