Class SharedKillSwitch
- java.lang.Object
-
- akka.stream.SharedKillSwitch
-
- All Implemented Interfaces:
KillSwitch
public final class SharedKillSwitch extends java.lang.Object implements KillSwitch
ASharedKillSwitchis a provider forGraphs ofFlowShapethat can be completed or failed from the outside. AGraphreturned by the switch can be materialized arbitrary amount of times: every newly materializedGraphbelongs to the switch from which it was acquired. MultipleSharedKillSwitchinstances are isolated from each other, shutting down or aborting on instance does not affect theGraphs provided by another instance.After calling
shutdown()all materialized, running instances of allGraphs provided by theSharedKillSwitchwill complete their downstreams and cancel their upstreams (unless if finished or failed already in which case the command is ignored). Subsequent invocations ofshutdown()andabort(java.lang.Throwable)will be ignored.After calling
abort(java.lang.Throwable)all materialized, running instances of allGraphs provided by theSharedKillSwitchwill fail their downstreams with the provided exception and cancel their upstreams (unless it finished or failed already in which case the command is ignored). Subsequent invocations ofshutdown()andabort(java.lang.Throwable)will be ignored.The
Graphs provided by theSharedKillSwitchdo not modify the passed through elements in any way or affect backpressure in the stream. All providedGraphs provide the parentSharedKillSwitchas materialized value.This class is thread-safe, the instance can be passed safely among threads and its methods may be invoked concurrently.
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidabort(java.lang.Throwable reason)After callingabort(java.lang.Throwable)all materialized, running instances of allGraphs provided by theSharedKillSwitchwill fail their downstreams with the provided exception and cancel their upstreams (unless it finished or failed already in which case the command is ignored).<T> Graph<FlowShape<T,T>,SharedKillSwitch>flow()Returns a typed Flow of a requested type that will be linked to thisSharedKillSwitchinstance.java.lang.Stringname()voidshutdown()After callingshutdown()all materialized, running instances of allGraphs provided by theSharedKillSwitchwill complete their downstreams and cancel their upstreams (unless if finished or failed already in which case the command is ignored).java.lang.StringtoString()
-
-
-
Method Detail
-
abort
public void abort(java.lang.Throwable reason)
After callingabort(java.lang.Throwable)all materialized, running instances of allGraphs provided by theSharedKillSwitchwill fail their downstreams with the provided exception and cancel their upstreams (unless it finished or failed already in which case the command is ignored). Subsequent invocations ofshutdown()andabort(java.lang.Throwable)will be ignored.These provided
Graphs materialize to their owning switch. This might make certain integrations simpler than passing around the switch instance itself.- Specified by:
abortin interfaceKillSwitch- Parameters:
reason- The exception to be used for failing the linkedGraphs
-
flow
public <T> Graph<FlowShape<T,T>,SharedKillSwitch> flow()
Returns a typed Flow of a requested type that will be linked to thisSharedKillSwitchinstance. By invokingshutdown()orabort(java.lang.Throwable)all running instances of all providedGraphs by this switch will be stopped normally or failed.- Returns:
- A reusable
Graphthat is linked with the switch. The materialized value provided is this switch itself.
-
name
public java.lang.String name()
-
shutdown
public void shutdown()
After callingshutdown()all materialized, running instances of allGraphs provided by theSharedKillSwitchwill complete their downstreams and cancel their upstreams (unless if finished or failed already in which case the command is ignored). Subsequent invocations ofshutdown()andabort(java.lang.Throwable)will be ignored.- Specified by:
shutdownin interfaceKillSwitch
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
-