YARN-10194. YARN RMWebServices /scheduler-conf/validate leaks ZK Connections. Contributed by Prabhu Joseph

This commit is contained in:
Szilard Nemeth 2020-04-28 17:52:14 +02:00
parent 5154f6eef4
commit 1dabbd5006
5 changed files with 27 additions and 8 deletions

View File

@ -43,14 +43,18 @@ public final class CapacitySchedulerConfigValidator {
public static boolean validateCSConfiguration( public static boolean validateCSConfiguration(
final Configuration oldConf, final Configuration newConf, final Configuration oldConf, final Configuration newConf,
final RMContext rmContext) throws IOException { final RMContext rmContext) throws IOException {
//TODO: extract all the validation steps and replace reinitialize with
//the specific validation steps
CapacityScheduler newCs = new CapacityScheduler(); CapacityScheduler newCs = new CapacityScheduler();
newCs.setConf(oldConf); try {
newCs.setRMContext(rmContext); //TODO: extract all the validation steps and replace reinitialize with
newCs.init(oldConf); //the specific validation steps
newCs.reinitialize(newConf, rmContext, true); newCs.setConf(oldConf);
return true; newCs.setRMContext(rmContext);
newCs.init(oldConf);
newCs.reinitialize(newConf, rmContext, true);
return true;
} finally {
newCs.stop();
}
} }
public static Set<String> validatePlacementRules( public static Set<String> validatePlacementRules(

View File

@ -348,6 +348,7 @@ public class FSSchedulerConfigurationStore extends YarnConfigurationStore {
return CURRENT_VERSION_INFO; return CURRENT_VERSION_INFO;
} }
@Override
public void close() throws IOException { public void close() throws IOException {
if (fileSystem != null) { if (fileSystem != null) {
fileSystem.close(); fileSystem.close();

View File

@ -22,6 +22,7 @@ import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.yarn.server.records.Version; import org.apache.hadoop.yarn.server.records.Version;
import org.apache.hadoop.yarn.server.resourcemanager.RMContext; import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
import java.io.IOException;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -148,4 +149,9 @@ public class InMemoryConfigurationStore extends YarnConfigurationStore {
public void checkVersion() { public void checkVersion() {
// Does nothing. (Version is always compatible since it's in memory) // Does nothing. (Version is always compatible since it's in memory)
} }
@Override
public void close() throws IOException {
// Does nothing.
}
} }

View File

@ -99,7 +99,7 @@ public abstract class YarnConfigurationStore {
* Closes the configuration store, releasing any required resources. * Closes the configuration store, releasing any required resources.
* @throws IOException on failure to close * @throws IOException on failure to close
*/ */
public void close() throws IOException {} public abstract void close() throws IOException;
/** /**
* Logs the configuration change to backing store. * Logs the configuration change to backing store.

View File

@ -31,6 +31,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.RMContext;
import org.apache.zookeeper.CreateMode; import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.data.ACL; import org.apache.zookeeper.data.ACL;
import java.io.IOException;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream; import java.io.ObjectInputStream;
@ -317,4 +318,11 @@ public class ZKConfigurationStore extends YarnConfigurationStore {
private static <T> T unsafeCast(Object o) throws ClassCastException { private static <T> T unsafeCast(Object o) throws ClassCastException {
return (T)o; return (T)o;
} }
@Override
public void close() throws IOException {
if (zkManager != null) {
zkManager.close();
}
}
} }