Package org.apache.commons.exec
Class ExecuteWatchdog
java.lang.Object
org.apache.commons.exec.ExecuteWatchdog
- All Implemented Interfaces:
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
Modifier and TypeClassDescriptionstatic final class
Builds ExecuteWatchdog instances. -
Field Summary
Modifier and TypeFieldDescriptionstatic final long
The marker for an infinite timeout.static final Duration
The marker for an infinite timeout. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionstatic ExecuteWatchdog.Builder
builder()
Creates a new builder.void
This method will rethrow the exception that was possibly caught during the run of the process.protected void
cleanUp()
reset the monitor flag and the process.void
Destroys the running process manually.void
Notification that starting the process failed.boolean
Indicates whether or not the watchdog is still monitoring the process.boolean
Indicates whether the last process run was killed.void
Watches the given process and terminates it, if it runs for too long.void
stop()
Stops the watcher.void
Called after watchdog has finished.
-
Field Details
-
INFINITE_TIMEOUT
The marker for an infinite timeout.- See Also:
-
INFINITE_TIMEOUT_DURATION
The marker for an infinite timeout.
-
-
Constructor Details
-
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 remains valid once the process has been terminated either by 'error', timeout or manual intervention. Information will be discarded once a new process is ran.- Throws:
Exception
- a wrapped exception over the one that was silently swallowed and stored during the process run.
-
cleanUp
reset the monitor flag and the process. -
destroyProcess
Destroys the running process manually. -
failedToStart
Notification that starting the process failed.- Parameters:
e
- the offending exception.
-
isWatching
Indicates whether or not the watchdog is still monitoring the process.- Returns:
true
if the process is still running, otherwisefalse
.
-
killedProcess
Indicates whether the last process run was killed.- Returns:
true
if the process was killedfalse
.
-
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
Stops the watcher. It will notify all threads possibly waiting on this object. -
timeoutOccured
Called after watchdog has finished.- Specified by:
timeoutOccured
in interfaceTimeoutObserver
- Parameters:
w
- the watchdog that timed out.
-
ExecuteWatchdog.Builder.get()
.