Spring Data for VMware GemFire
Annotation Interface EnableGatewaySenders
@Target(TYPE)
@Retention(RUNTIME)
@Inherited
@Documented
@Import({GatewaySenderBeanFactoryPostProcessor.class,GatewaySendersConfiguration.class})
public @interface EnableGatewaySenders
This 
Annotation is responsible for the configuration of multiple GatewaySenders.
 All properties set with this Annotation will be used as the default values for all
 GatewaySenders configured within the gatewaySenders property.- Since:
- 2.2.0
- See Also:
- 
- Annotation
- Documented
- Inherited
- Retention
- Target
- GatewayEventFilter
- GatewayEventSubstitutionFilter
- GatewayReceiver
- GatewaySender
- GatewaySender.OrderPolicy
- GatewayTransportFilter
- EnableGatewaySender
 
- 
Optional Element SummaryOptional ElementsModifier and TypeOptional ElementDescriptionintConfigures the time, in milliseconds, that an object can be in the queue to be replicated before the configuredGatewwaySenderslog an alert.booleanA boolean flag to indicate if the configuredGatewaySendersshould use conflate entries in each batch.intConfigures the maximum batch size that all configuredGatewaySenderssends to the remote site.intConfigures the maximum batch time interval in milliseconds that all configuredGatewaySenderswait before attempting to send a batch of queued objects to the remoteGatewayReceivers.Configures theDiskStoreused by all configured GatewaySender GatewaySenders} when persisting theGatewaySendersqueue data.booleanA boolean flag indicating whether all configuredGatewaySendersshould use synchronousDiskStorewrites.intConfigures the number of dispatcher threads that all configuredGatewaySenderswill try to use to dispatch the queued events.String[]Configures the list ofGatewayEventFiltersto be applied to all configuredGatewaySenders.Configures theGatewayEventSubstitutionFilterused by all configuredGatewaySenders.The list ofGatewaySendersto be configured.booleanA boolean flag indicating whether all configuredGatewaySendersshould be started automatically.intConfigures the maximum size in megabytes that all configuredGatewaySendersqueue may take in heap memory before overflowing to disk.Configures the ordering policy that all configuredGatewaySenderswill use when queueing entries to be replicated to a remoteGatewayReceiver.booleanA boolean} flag indicating whether all configuredGatewaySendersshould use parallel replication.booleanA boolean flag indicating whether all configuredGatewaySendersshould use persistence.String[]Configures the list ofRegionnames that will be configured for allGatewaySenders.intConfigures the id of the remote distributed system (cluster) that all configuredGatewaySenderswill send their data to.intConfigures the socket buffer size in bytes for all configuredGatewaySenders.intConfigures the amount of time in milliseconds that all configuredGatewaySenderswill wait to receive an acknowledgment from a remote site.String[]Configures an in-order list ofGatewayTransportFilterobjects to be applied to all configuredGatewaySenders.
- 
Element Details- 
alertThresholdint alertThresholdConfigures the time, in milliseconds, that an object can be in the queue to be replicated before the configuredGatewwaySenderslog an alert. Defaults toGatewaySenderConfiguration.DEFAULT_ALERT_THRESHOLD. Alternatively use the spring.data.gemfire.gateway.sender.alert-threshold property in application.properties.- Default:
- 0
 
- 
batchConflationEnabledboolean batchConflationEnabledA boolean flag to indicate if the configuredGatewaySendersshould use conflate entries in each batch. This means, that a batch will never contain duplicate entries, as the batch will always only contain the latest value for a key. Defaults to false. Alternatively use the spring.data.gemfire.gateway.sender.batch-conflation-enabled property in application.properties.- Default:
- false
 
- 
batchSizeint batchSizeConfigures the maximum batch size that all configuredGatewaySenderssends to the remote site. This property works in conjunction with thebatchTimeInterval()setting. AGatewaySenderwill send when either the batch-size or batch-time-interval is reached. Defaults to 100. Alternatively use the spring.data.gemfire.gateway.sender.batch-size property in application.properties.- Default:
- 100
 
- 
batchTimeIntervalint batchTimeIntervalConfigures the maximum batch time interval in milliseconds that all configuredGatewaySenderswait before attempting to send a batch of queued objects to the remoteGatewayReceivers. This property works in conjunction with thebatchSize()setting. AGatewaySenderwill send when either the batch-size or batch-time-interval is reached. Defaults to 1000. Alternatively use the spring.data.gemfire.gateway.sender.batch-time-interval property in application.properties.- Default:
- 1000
 
- 
diskStoreReferenceString diskStoreReferenceConfigures theDiskStoreused by all configured GatewaySender GatewaySenders} when persisting theGatewaySendersqueue data. This setting should be set when theEnableGatewaySender.persistent()property is set to true. Defaults to "". Alternatively use the spring.data.gemfire.gateway.sender.diskstore-reference property in application.properties.- Default:
- ""
 
- 
diskSynchronousboolean diskSynchronousA boolean flag indicating whether all configuredGatewaySendersshould use synchronousDiskStorewrites. Defaults to true. Alternatively use the spring.data.gemfire.gateway.sender.disk-synchronous property in application.properties.- Default:
- true
 
- 
dispatcherThreadsint dispatcherThreadsConfigures the number of dispatcher threads that all configuredGatewaySenderswill try to use to dispatch the queued events. Defaults to 5. Alternatively use the spring.data.gemfire.gateway.sender.dispatcher-threads property in application.properties.- Default:
- 5
 
- 
eventFiltersString[] eventFiltersConfigures the list ofGatewayEventFiltersto be applied to all configuredGatewaySenders.GatewayEventFiltersare used to filter out objects from the sending queue before dispatching them to remoteGatewayReceivers. Defaults to empty list. Alternatively use the spring.data.gemfire.gateway.sender.event-filters property in application.properties.- Default:
- {}
 
- 
eventSubstitutionFilterString eventSubstitutionFilterConfigures theGatewayEventSubstitutionFilterused by all configuredGatewaySenders. TheGatewayEventSubstitutionFilteris used to replace values on objects before they are enqueued for remote replication. Defaults toGatewaySenderConfiguration.DEFAULT_EVENT_SUBSTITUTION_FILTER. Alternatively use the spring.data.gemfire.gateway.sender.event-substitution-filter property in application.properties.- Default:
- ""
 
- 
gatewaySendersEnableGatewaySender[] gatewaySendersThe list ofGatewaySendersto be configured. If noGatewaySenders) are configured, a default {@link GatewaySender} will be created using the properties provided.- Default:
- {}
 
- 
manualStartboolean manualStartA boolean flag indicating whether all configuredGatewaySendersshould be started automatically.Defaults to {@value @EnableGatewaySenderConfiguration.DEFAULT_MANUAL_START}. Alternatively use the spring.data.gemfire.gateway.sender.manual-start property in application.properties. - Default:
- false
 
- 
maximumQueueMemoryint maximumQueueMemoryConfigures the maximum size in megabytes that all configuredGatewaySendersqueue may take in heap memory before overflowing to disk. Defaults to 100. Alternatively use the spring.data.gemfire.gateway.sender.maximum-queue-memory property in application.properties.- Default:
- 100
 
- 
orderPolicyOrderPolicyType orderPolicyConfigures the ordering policy that all configuredGatewaySenderswill use when queueing entries to be replicated to a remoteGatewayReceiver.There are three different ordering policies: - OrderPolicyType.KEY- Order of events preserved on a per key basis
- OrderPolicyType.THREAD- Order of events preserved by the thread that added the event
- OrderPolicyType.PARTITION- Order of events is preserved in order that they arrived in partitioned Region
 OrderPolicyType.KEY. Alternatively use the spring.data.gemfire.gateway.sender.order-policy property in application.properties.- Default:
- KEY
 
- 
parallelboolean parallelA boolean} flag indicating whether all configuredGatewaySendersshould use parallel replication. Parallel replication means that eachCacheServerthat defines aGatewaySenderwill send data to a remoteGatewayReceiver. Defaults to false. Alternatively use the spring.data.gemfire.gateway.sender.parallel property in application.properties.- Default:
- false
 
- 
persistentboolean persistentA boolean flag indicating whether all configuredGatewaySendersshould use persistence. This setting should be used in conjunction with the disk-store-reference property. Defaults to false. Alternatively use the spring.data.gemfire.gateway.sender.persistent property in application.properties.- Default:
- false
 
- 
regionsString[] regionsConfigures the list ofRegionnames that will be configured for allGatewaySenders. An empty list denotes that ALLRegionsare to be replicated to the remoteGatewayReceiver. Defaults to empty list. Alternatively use the spring.data.gemfire.gateway.sender.region-names property in application.properties.- Default:
- {}
 
- 
remoteDistributedSystemIdint remoteDistributedSystemIdConfigures the id of the remote distributed system (cluster) that all configuredGatewaySenderswill send their data to. Defaults to {@value @EnableGatewaySenderConfiguration.DEFAULT_REMOTE_DISTRIBUTED_SYSTEM_ID}. Alternatively use the spring.data.gemfire.gateway.sender.remote-distributed-system-id property in application.properties.- Default:
- -1
 
- 
socketBufferSizeint socketBufferSizeConfigures the socket buffer size in bytes for all configuredGatewaySenders. Defaults to 524288. Alternatively use the spring.data.gemfire.gateway.sender.socket-buffer-size property in application.properties.- Default:
- 524288
 
- 
socketReadTimeoutint socketReadTimeoutConfigures the amount of time in milliseconds that all configuredGatewaySenderswill wait to receive an acknowledgment from a remote site. By default this is set to 0, which means there is no timeout. The minimum allowed timeout is 30000 (milliseconds). Defaults to 0. Alternatively use the spring.data.gemfire.gateway.sender.socket-read-timeout property in application.properties.- Default:
- 0
 
- 
transportFiltersString[] transportFiltersConfigures an in-order list ofGatewayTransportFilterobjects to be applied to all configuredGatewaySenders. Defaults to empty list. Alternatively use the spring.data.gemfire.gateway.sender.transport-filters property in application.properties.- Default:
- {}
 
 
- 
