HADOOP-18455. S3A prefetching executor should be closed (#4879)

follow-on patch to HADOOP-18186. 

Contributed by: Viraj Jasani
This commit is contained in:
Viraj Jasani 2022-09-21 11:52:41 -07:00 committed by Steve Loughran
parent 1c2c6785a0
commit f07be3bec2
No known key found for this signature in database
GPG Key ID: D22CF846DBB162A0
4 changed files with 29 additions and 10 deletions

View File

@ -22,8 +22,13 @@
import java.util.Locale; import java.util.Locale;
import java.util.concurrent.ExecutorService; import java.util.concurrent.ExecutorService;
import java.util.concurrent.Future; import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.function.Supplier; import java.util.function.Supplier;
import org.slf4j.Logger;
import org.apache.hadoop.util.concurrent.HadoopExecutors;
/** /**
* A FuturePool implementation backed by a java.util.concurrent.ExecutorService. * A FuturePool implementation backed by a java.util.concurrent.ExecutorService.
* *
@ -37,7 +42,8 @@
* *
*/ */
public class ExecutorServiceFuturePool { public class ExecutorServiceFuturePool {
private ExecutorService executor;
private final ExecutorService executor;
public ExecutorServiceFuturePool(ExecutorService executor) { public ExecutorServiceFuturePool(ExecutorService executor) {
this.executor = executor; this.executor = executor;
@ -64,6 +70,18 @@ public Future<Void> executeRunnable(final Runnable r) {
return (Future<Void>) executor.submit(r::run); return (Future<Void>) executor.submit(r::run);
} }
/**
* Utility to shutdown the {@link ExecutorService} used by this class. Will wait up to a
* certain timeout for the ExecutorService to gracefully shutdown.
*
* @param logger Logger
* @param timeout the maximum time to wait
* @param unit the time unit of the timeout argument
*/
public void shutdown(Logger logger, long timeout, TimeUnit unit) {
HadoopExecutors.shutdown(executor, logger, timeout, unit);
}
public String toString() { public String toString() {
return String.format(Locale.ROOT, "ExecutorServiceFuturePool(executor=%s)", executor); return String.format(Locale.ROOT, "ExecutorServiceFuturePool(executor=%s)", executor);
} }

View File

@ -115,9 +115,8 @@ public static void shutdown(ExecutorService executorService, Logger logger,
try { try {
executorService.shutdown(); executorService.shutdown();
logger.debug( logger.debug("Gracefully shutting down executor service {}. Waiting max {} {}",
"Gracefully shutting down executor service. Waiting max {} {}", executorService, timeout, unit);
timeout, unit);
if (!executorService.awaitTermination(timeout, unit)) { if (!executorService.awaitTermination(timeout, unit)) {
logger.debug( logger.debug(
"Executor service has not shutdown yet. Forcing. " "Executor service has not shutdown yet. Forcing. "

View File

@ -59,6 +59,10 @@
<Method name="openFileWithOptions"/> <Method name="openFileWithOptions"/>
<Bug pattern="RV_RETURN_VALUE_IGNORED_BAD_PRACTICE"/> <Bug pattern="RV_RETURN_VALUE_IGNORED_BAD_PRACTICE"/>
</Match> </Match>
<Match>
<Class name="org.apache.hadoop.fs.s3a.S3AFileSystem"/>
<Bug pattern="IS2_INCONSISTENT_SYNC"/>
</Match>
<Match> <Match>
<Class name="org.apache.hadoop.fs.s3a.s3guard.S3GuardTool$BucketInfo"/> <Class name="org.apache.hadoop.fs.s3a.s3guard.S3GuardTool$BucketInfo"/>
<Method name="run"/> <Method name="run"/>

View File

@ -653,17 +653,11 @@ public void initialize(URI name, Configuration originalConf)
// amazon client exception: stop all services then throw the translation // amazon client exception: stop all services then throw the translation
cleanupWithLogger(LOG, span); cleanupWithLogger(LOG, span);
stopAllServices(); stopAllServices();
if (this.futurePool != null) {
this.futurePool = null;
}
throw translateException("initializing ", new Path(name), e); throw translateException("initializing ", new Path(name), e);
} catch (IOException | RuntimeException e) { } catch (IOException | RuntimeException e) {
// other exceptions: stop the services. // other exceptions: stop the services.
cleanupWithLogger(LOG, span); cleanupWithLogger(LOG, span);
stopAllServices(); stopAllServices();
if (this.futurePool != null) {
this.futurePool = null;
}
throw e; throw e;
} }
} }
@ -4056,6 +4050,10 @@ protected synchronized void stopAllServices() {
HadoopExecutors.shutdown(unboundedThreadPool, LOG, HadoopExecutors.shutdown(unboundedThreadPool, LOG,
THREAD_POOL_SHUTDOWN_DELAY_SECONDS, TimeUnit.SECONDS); THREAD_POOL_SHUTDOWN_DELAY_SECONDS, TimeUnit.SECONDS);
unboundedThreadPool = null; unboundedThreadPool = null;
if (futurePool != null) {
futurePool.shutdown(LOG, THREAD_POOL_SHUTDOWN_DELAY_SECONDS, TimeUnit.SECONDS);
futurePool = null;
}
// other services are shutdown. // other services are shutdown.
cleanupWithLogger(LOG, cleanupWithLogger(LOG,
instrumentation, instrumentation,