Class XSiteStatePushCommand
- java.lang.Object
-
- org.infinispan.commands.remote.BaseRpcCommand
-
- org.infinispan.xsite.XSiteReplicateCommand
-
- org.infinispan.xsite.statetransfer.XSiteStatePushCommand
-
- All Implemented Interfaces:
CacheRpcCommand,ReplicableCommand
public class XSiteStatePushCommand extends XSiteReplicateCommand
Wraps the state to be sent to another site- Since:
- 7.0
- Author:
- Pedro Ruivo
-
-
Field Summary
Fields Modifier and Type Field Description static byteCOMMAND_ID-
Fields inherited from class org.infinispan.xsite.XSiteReplicateCommand
originSite
-
Fields inherited from class org.infinispan.commands.remote.BaseRpcCommand
cacheName, origin
-
-
Constructor Summary
Constructors Constructor Description XSiteStatePushCommand()XSiteStatePushCommand(ByteString cacheName)XSiteStatePushCommand(ByteString cacheName, XSiteState[] chunk, long timeoutMillis)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancanBlock()If true, the command is processed asynchronously in a thread provided by an Infinispan thread pool.XSiteState[]getChunk()bytegetCommandId()Used by marshallers to convert this command into an id for streaming.longgetTimeout()CompletionStage<?>invokeAsync(ComponentRegistry componentRegistry)Invoke the command asynchronously.booleanisReturnValueExpected()If true, a return value will be provided when performed remotely.CompletionStage<Void>performInLocalSite(BackupReceiver receiver, boolean preserveOrder)voidreadFrom(ObjectInput input)Reads this instance from the stream written byReplicableCommand.writeTo(ObjectOutput).StringtoString()voidwriteTo(ObjectOutput output)Writes this instance to theObjectOutput.-
Methods inherited from class org.infinispan.xsite.XSiteReplicateCommand
setOriginSite
-
Methods inherited from class org.infinispan.commands.remote.BaseRpcCommand
getCacheName, getOrigin, setOrigin
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.infinispan.commands.ReplicableCommand
invoke, invokeAsync, isSuccessful
-
-
-
-
Field Detail
-
COMMAND_ID
public static final byte COMMAND_ID
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
XSiteStatePushCommand
public XSiteStatePushCommand(ByteString cacheName, XSiteState[] chunk, long timeoutMillis)
-
XSiteStatePushCommand
public XSiteStatePushCommand(ByteString cacheName)
-
XSiteStatePushCommand
public XSiteStatePushCommand()
-
-
Method Detail
-
performInLocalSite
public CompletionStage<Void> performInLocalSite(BackupReceiver receiver, boolean preserveOrder)
- Specified by:
performInLocalSitein classXSiteReplicateCommand
-
getChunk
public XSiteState[] getChunk()
-
getTimeout
public long getTimeout()
-
invokeAsync
public CompletionStage<?> invokeAsync(ComponentRegistry componentRegistry) throws Throwable
Description copied from interface:CacheRpcCommandInvoke the command asynchronously.This method replaces
ReplicableCommand.invoke()for remote execution. The default implementation andReplicableCommand.invoke()will be removed in future versions.- Throws:
Throwable
-
getCommandId
public byte getCommandId()
Description copied from interface:ReplicableCommandUsed by marshallers to convert this command into an id for streaming.- Specified by:
getCommandIdin interfaceReplicableCommand- Overrides:
getCommandIdin classXSiteReplicateCommand- Returns:
- the method id of this command. This is compatible with pre-2.2.0 MethodCall ids.
-
writeTo
public void writeTo(ObjectOutput output) throws IOException
Description copied from interface:ReplicableCommandWrites this instance to theObjectOutput.- Parameters:
output- the stream.- Throws:
IOException- if an error occurred during the I/O.
-
readFrom
public void readFrom(ObjectInput input) throws IOException, ClassNotFoundException
Description copied from interface:ReplicableCommandReads this instance from the stream written byReplicableCommand.writeTo(ObjectOutput).- Parameters:
input- the stream to read.- Throws:
IOException- if an error occurred during the I/O.ClassNotFoundException- if it tries to load an undefined class.
-
isReturnValueExpected
public boolean isReturnValueExpected()
Description copied from interface:ReplicableCommandIf true, a return value will be provided when performed remotely. Otherwise, a remoteResponseGeneratormay choose to simply return null to save on marshalling costs.- Specified by:
isReturnValueExpectedin interfaceReplicableCommand- Overrides:
isReturnValueExpectedin classXSiteReplicateCommand- Returns:
- true or false
-
canBlock
public boolean canBlock()
Description copied from interface:ReplicableCommandIf true, the command is processed asynchronously in a thread provided by an Infinispan thread pool. Otherwise, the command is processed directly in the JGroups thread. This feature allows to avoid keep a JGroups thread busy that can originate discard of messages and retransmissions. So, the commands that can block (waiting for some state, acquiring locks, etc.) should return true.- Returns:
trueif the command can block/wait,falseotherwise
-
toString
public String toString()
- Overrides:
toStringin classBaseRpcCommand
-
-