Package org.apache.qpid.protonj2.client
Class StreamSenderOptions
- java.lang.Object
- 
- org.apache.qpid.protonj2.client.SenderOptions
- 
- org.apache.qpid.protonj2.client.StreamSenderOptions
 
 
- 
 public class StreamSenderOptions extends SenderOptions Options class that controls various aspects of aStreamSenderMessageinstance and how a streamed message transfer is written.
- 
- 
Field SummaryFields Modifier and Type Field Description static intDEFAULT_PENDING_WRITES_BUFFER_SIZEDefines the default pending write buffering size which is used to control how much outgoing data can be buffered for local writing before the sender has back pressured applied to avoid out of memory conditions due to overly large pending batched writes.static intMIN_BUFFER_SIZE_LIMITDefines the default minimum size that the context write buffer will allocate which drives the interval auto flushing of written data for this context.
 - 
Constructor SummaryConstructors Constructor Description StreamSenderOptions()Creates aStreamSenderOptionsinstance with default values for all optionsStreamSenderOptions(StreamSenderOptions options)Create aStreamSenderOptionsinstance that copies all configuration from the givenStreamSenderOptionsinstance.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description StreamSenderOptionsautoSettle(boolean autoSettle)Sets whether sent deliveries should be automatically locally-settled once they have become remotely-settled by the receiving peer.StreamSenderOptionsclone()StreamSenderOptionscloseTimeout(long closeTimeout)Configures the timeout used when awaiting a response from the remote that a request to close theSenderlink.StreamSenderOptionscloseTimeout(long timeout, java.util.concurrent.TimeUnit units)Configures the timeout used when awaiting a response from the remote that a request to close theSenderlink.protected StreamSenderOptionscopyInto(StreamSenderOptions other)Copy all options from thisStreamSenderOptionsinstance into the instance provided.StreamSenderOptionsdeliveryMode(DeliveryMode deliveryMode)Sets theDeliveryModevalue to assign to newly createdSenderinstances.StreamSenderOptionsdesiredCapabilities(java.lang.String... desiredCapabilities)StreamSenderOptionslinkName(java.lang.String linkName)Configures the link name to use when creating a givenSenderinstance.StreamSenderOptionsofferedCapabilities(java.lang.String... offeredCapabilities)StreamSenderOptionsopenTimeout(long openTimeout)Configures the timeout used when awaiting a response from the remote that a request to open aSenderhas been honored.StreamSenderOptionsopenTimeout(long timeout, java.util.concurrent.TimeUnit units)Configures the timeout used when awaiting a response from the remote that a request to open aSenderhas been honored.intpendingWritesBufferSize()StreamSenderOptionspendingWritesBufferSize(int pendingWritesBufferSize)Sets the overall number of bytes the stream sender will allow to be pending for write before applying back pressure to the stream write caller.StreamSenderOptionsproperties(java.util.Map<java.lang.String,java.lang.Object> properties)StreamSenderOptionsrequestTimeout(long requestTimeout)Configures the timeout used when awaiting a response from the remote that a request to perform some action such as starting a new transaction.StreamSenderOptionsrequestTimeout(long timeout, java.util.concurrent.TimeUnit units)Configures the timeout used when awaiting a response from the remote that a request to perform some action such as starting a new transaction.StreamSenderOptionssendTimeout(long sendTimeout)Configures the timeout used when awaiting a send operation to complete.StreamSenderOptionssendTimeout(long timeout, java.util.concurrent.TimeUnit units)Configures the timeout used when awaiting a send operation to complete.intwriteBufferSize()StreamSenderOptionswriteBufferSize(int writeBufferSize)Sets the overall number of bytes the stream sender will buffer before automatically flushing the currently buffered bytes.- 
Methods inherited from class org.apache.qpid.protonj2.client.SenderOptionsautoSettle, closeTimeout, copyInto, deliveryMode, desiredCapabilities, linkName, offeredCapabilities, openTimeout, properties, requestTimeout, sendTimeout, sourceOptions, targetOptions
 
- 
 
- 
- 
- 
Field Detail- 
DEFAULT_PENDING_WRITES_BUFFER_SIZEpublic static final int DEFAULT_PENDING_WRITES_BUFFER_SIZE Defines the default pending write buffering size which is used to control how much outgoing data can be buffered for local writing before the sender has back pressured applied to avoid out of memory conditions due to overly large pending batched writes.- See Also:
- Constant Field Values
 
 - 
MIN_BUFFER_SIZE_LIMITpublic static final int MIN_BUFFER_SIZE_LIMIT Defines the default minimum size that the context write buffer will allocate which drives the interval auto flushing of written data for this context.- See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
StreamSenderOptionspublic StreamSenderOptions() Creates aStreamSenderOptionsinstance with default values for all options
 - 
StreamSenderOptionspublic StreamSenderOptions(StreamSenderOptions options) Create aStreamSenderOptionsinstance that copies all configuration from the givenStreamSenderOptionsinstance.- Parameters:
- options- The options instance to copy all configuration values from.
 
 
- 
 - 
Method Detail- 
clonepublic StreamSenderOptions clone() - Overrides:
- clonein class- SenderOptions
 
 - 
copyIntoprotected StreamSenderOptions copyInto(StreamSenderOptions other) Copy all options from thisStreamSenderOptionsinstance into the instance provided.- Parameters:
- other- the target of this copy operation.
- Returns:
- this StreamSenderOptionsclass for chaining.
 
 - 
writeBufferSizepublic int writeBufferSize() - Returns:
- the configured context write buffering limit for the associated StreamSender
 
 - 
writeBufferSizepublic StreamSenderOptions writeBufferSize(int writeBufferSize) Sets the overall number of bytes the stream sender will buffer before automatically flushing the currently buffered bytes. By default the stream sender implementation chooses a value for this buffer limit based on the configured frame size limits of the connection.- Parameters:
- writeBufferSize- The number of bytes that can be written before the context performs a flush operation.
- Returns:
- this StreamSenderOptionsinstance.
 
 - 
pendingWritesBufferSizepublic int pendingWritesBufferSize() - Returns:
- the configured pending write buffering limit for the associated StreamSender
 
 - 
pendingWritesBufferSizepublic StreamSenderOptions pendingWritesBufferSize(int pendingWritesBufferSize) Sets the overall number of bytes the stream sender will allow to be pending for write before applying back pressure to the stream write caller. By default the stream sender implementation chooses a value for this pending write limit based on the configured frame size limits of the connection. This is an advanced option and should not be used unless the impact of doing so is understood by the user.- Parameters:
- pendingWritesBufferSize- The number of bytes that can be pending for write before the sender applies back pressure.
- Returns:
- this StreamSenderOptionsinstance.
 
 - 
linkNamepublic StreamSenderOptions linkName(java.lang.String linkName) Description copied from class:SenderOptionsConfigures the link name to use when creating a givenSenderinstance.- Overrides:
- linkNamein class- SenderOptions
- Parameters:
- linkName- The assigned link name to use when creating a- Sender.
- Returns:
- this SenderOptionsinstance.
 
 - 
autoSettlepublic StreamSenderOptions autoSettle(boolean autoSettle) Description copied from class:SenderOptionsSets whether sent deliveries should be automatically locally-settled once they have become remotely-settled by the receiving peer. True by default.- Overrides:
- autoSettlein class- SenderOptions
- Parameters:
- autoSettle- whether deliveries should be auto settled locally after being settled by the receiver
- Returns:
- the sender
 
 - 
deliveryModepublic StreamSenderOptions deliveryMode(DeliveryMode deliveryMode) Description copied from class:SenderOptionsSets theDeliveryModevalue to assign to newly createdSenderinstances.- Overrides:
- deliveryModein class- SenderOptions
- Parameters:
- deliveryMode- The delivery mode value to configure.
- Returns:
- this SenderOptionsinstance.
 
 - 
closeTimeoutpublic StreamSenderOptions closeTimeout(long closeTimeout) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a response from the remote that a request to close theSenderlink.- Overrides:
- closeTimeoutin class- SenderOptions
- Parameters:
- closeTimeout- Timeout value in milliseconds to wait for a remote response.
- Returns:
- this SenderOptionsinstance.
 
 - 
closeTimeoutpublic StreamSenderOptions closeTimeout(long timeout, java.util.concurrent.TimeUnit units) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a response from the remote that a request to close theSenderlink.- Overrides:
- closeTimeoutin class- SenderOptions
- Parameters:
- timeout- Timeout value to wait for a remote response.
- units- The- TimeUnitthat defines the timeout span.
- Returns:
- this SenderOptionsinstance.
 
 - 
openTimeoutpublic StreamSenderOptions openTimeout(long openTimeout) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a response from the remote that a request to open aSenderhas been honored.- Overrides:
- openTimeoutin class- SenderOptions
- Parameters:
- openTimeout- Timeout value in milliseconds to wait for a remote response.
- Returns:
- this SenderOptionsinstance.
 
 - 
openTimeoutpublic StreamSenderOptions openTimeout(long timeout, java.util.concurrent.TimeUnit units) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a response from the remote that a request to open aSenderhas been honored.- Overrides:
- openTimeoutin class- SenderOptions
- Parameters:
- timeout- Timeout value to wait for a remote response.
- units- The- TimeUnitthat defines the timeout span.
- Returns:
- this SenderOptionsinstance.
 
 - 
sendTimeoutpublic StreamSenderOptions sendTimeout(long sendTimeout) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a send operation to complete. A send will block if the remote has not granted theSenderor theSessioncredit to do so, if the send blocks for longer than this timeout the send call will fail with anClientSendTimedOutExceptionexception to indicate that the send did not complete.- Overrides:
- sendTimeoutin class- SenderOptions
- Parameters:
- sendTimeout- Timeout value in milliseconds to wait for a remote response.
- Returns:
- this SenderOptionsinstance.
 
 - 
sendTimeoutpublic StreamSenderOptions sendTimeout(long timeout, java.util.concurrent.TimeUnit units) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a send operation to complete. A send will block if the remote has not granted theSenderor theSessioncredit to do so, if the send blocks for longer than this timeout the send call will fail with anClientSendTimedOutExceptionexception to indicate that the send did not complete.- Overrides:
- sendTimeoutin class- SenderOptions
- Parameters:
- timeout- Timeout value to wait for a remote response.
- units- The- TimeUnitthat defines the timeout span.
- Returns:
- this SenderOptionsinstance.
 
 - 
requestTimeoutpublic StreamSenderOptions requestTimeout(long requestTimeout) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a response from the remote that a request to perform some action such as starting a new transaction. If the remote does not respond within the configured timeout the resource making the request will mark it as failed and return an error to the request initiator usually in the form of aClientOperationTimedOutException.- Overrides:
- requestTimeoutin class- SenderOptions
- Parameters:
- requestTimeout- Timeout value in milliseconds to wait for a remote response.
- Returns:
- this SenderOptionsinstance.
 
 - 
requestTimeoutpublic StreamSenderOptions requestTimeout(long timeout, java.util.concurrent.TimeUnit units) Description copied from class:SenderOptionsConfigures the timeout used when awaiting a response from the remote that a request to perform some action such as starting a new transaction. If the remote does not respond within the configured timeout the resource making the request will mark it as failed and return an error to the request initiator usually in the form of aClientOperationTimedOutException.- Overrides:
- requestTimeoutin class- SenderOptions
- Parameters:
- timeout- Timeout value to wait for a remote response.
- units- The- TimeUnitthat defines the timeout span.
- Returns:
- this SenderOptionsinstance.
 
 - 
offeredCapabilitiespublic StreamSenderOptions offeredCapabilities(java.lang.String... offeredCapabilities) - Overrides:
- offeredCapabilitiesin class- SenderOptions
- Parameters:
- offeredCapabilities- the offeredCapabilities to set
- Returns:
- this SenderOptionsinstance.
 
 - 
desiredCapabilitiespublic StreamSenderOptions desiredCapabilities(java.lang.String... desiredCapabilities) - Overrides:
- desiredCapabilitiesin class- SenderOptions
- Parameters:
- desiredCapabilities- the desiredCapabilities to set
- Returns:
- this SenderOptionsinstance.
 
 - 
propertiespublic StreamSenderOptions properties(java.util.Map<java.lang.String,java.lang.Object> properties) - Overrides:
- propertiesin class- SenderOptions
- Parameters:
- properties- the properties to set
- Returns:
- this SenderOptionsinstance.
 
 
- 
 
-