Class ExecuteWatchdog
java.lang.Object
org.apache.commons.exec.ExecuteWatchdog
- All Implemented Interfaces:
Consumer<Watchdog>, TimeoutObserver
Destroys a process running for too long. For example:
ExecuteWatchdog watchdog = ExecuteWatchdog.builder().setTimeout(Duration.ofSeconds(30)).get();
Executor executor = DefaultExecutor.builder().setExecuteStreamHandler(new PumpStreamHandler()).get();
executor.setWatchdog(watchdog);
int exitValue = executor.execute(myCommandLine);
if (executor.isFailure(exitValue) && watchdog.killedProcess()) {
// it was killed on purpose by the watchdog
}
When starting an asynchronous process than 'ExecuteWatchdog' is the keeper of the process handle. In some cases it is useful not to define a timeout (and
pass INFINITE_TIMEOUT_DURATION) and to kill the process explicitly using destroyProcess().
Please note that ExecuteWatchdog is processed asynchronously, e.g. it might be still attached to a process even after the
DefaultExecutor.execute(CommandLine) or a variation has returned.
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic final classBuilds ExecuteWatchdog instances. -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate ExceptionException that might be thrown during the process execution.private final booleanIs a user-supplied timeout in use.static final longThe marker for an infinite timeout.static final DurationThe marker for an infinite timeout.private booleanSay whether the process was killed due to running overtime.private ProcessThe process to execute and watch for duration.private booleanIndicates that the process is verified as startedprivate final ThreadFactoryThe thread factory.private booleanSay whether the watchdog is currently monitoring a process.private final WatchdogWill tell us whether timeout has occurred. -
Constructor Summary
ConstructorsModifierConstructorDescriptionExecuteWatchdog(long timeoutMillis) Deprecated.privateExecuteWatchdog(ExecuteWatchdog.Builder builder) Creates a new watchdog with a given timeout. -
Method Summary
Modifier and TypeMethodDescriptionstatic ExecuteWatchdog.Builderbuilder()Creates a new builder.voidThis method will rethrow the exception that was possibly caught during the run of the process.protected voidcleanUp()Resets the monitor flag and the process.voidDestroys the running process manually.private voidEnsures that the process is started or not already terminated so we do not race with asynch executionor hang forever.voidNotification that starting the process failed.(package private) WatchdogGets the watchdog.booleanTests whether the watchdog is still monitoring the process.booleanTests whether the last process run was killed.(package private) voidvoidWatches the given process and terminates it, if it runs for too long.voidstop()Stops the watcher.voidCalled after watchdog has finished.Methods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface TimeoutObserver
accept
-
Field Details
-
INFINITE_TIMEOUT
public static final long INFINITE_TIMEOUTThe marker for an infinite timeout.- See Also:
-
INFINITE_TIMEOUT_DURATION
The marker for an infinite timeout. -
caught
Exception that might be thrown during the process execution. -
hasWatchdog
private final boolean hasWatchdogIs a user-supplied timeout in use. -
killedProcess
private boolean killedProcessSay whether the process was killed due to running overtime. -
process
The process to execute and watch for duration. -
processStarted
private volatile boolean processStartedIndicates that the process is verified as started -
threadFactory
The thread factory. -
watch
private boolean watchSay whether the watchdog is currently monitoring a process. -
watchdog
Will tell us whether timeout has occurred.
-
-
Constructor Details
-
ExecuteWatchdog
Creates a new watchdog with a given timeout.- Parameters:
threadFactory- the thread factory.timeout- the timeout Duration for the process. It must be greater than 0 orINFINITE_TIMEOUT_DURATION.
-
ExecuteWatchdog
Deprecated.Creates a new watchdog with a given timeout.- Parameters:
timeoutMillis- the timeout for the process in milliseconds. It must be greater than 0 orINFINITE_TIMEOUT.
-
-
Method Details
-
builder
Creates a new builder.- Returns:
- a new builder.
- Since:
- 1.4.0
-
checkException
This method will rethrow the exception that was possibly caught during the run of the process. It will only remain valid once the process has been terminated either by 'error', timeout or manual intervention. Information will be discarded once a new process is run.- Throws:
Exception- a wrapped exception over the one that was silently swallowed and stored during the process run.
-
cleanUp
protected void cleanUp()Resets the monitor flag and the process. -
destroyProcess
public void destroyProcess()Destroys the running process manually. -
ensureStarted
private void ensureStarted()Ensures that the process is started or not already terminated so we do not race with asynch executionor hang forever. The caller of this method must be holding the lock on this. -
failedToStart
Notification that starting the process failed.- Parameters:
e- the offending exception.
-
getWatchdog
-
isWatching
public boolean isWatching()Tests whether the watchdog is still monitoring the process.- Returns:
trueif the process is still running, otherwisefalse.
-
killedProcess
public boolean killedProcess()Tests whether the last process run was killed.- Returns:
trueif the process was killedfalse.
-
setProcessNotStarted
void setProcessNotStarted() -
start
Watches the given process and terminates it, if it runs for too long. All information from the previous run are reset.- Parameters:
processToMonitor- the process to monitor. It cannot benull.- Throws:
IllegalStateException- if a process is still being monitored.
-
stop
public void stop()Stops the watcher. It will notify all threads possibly waiting on this object. -
timeoutOccured
Called after watchdog has finished.- Specified by:
timeoutOccuredin interfaceTimeoutObserver- Parameters:
w- the watchdog that timed out.
-
ExecuteWatchdog.Builder.get().