Click or drag to resize

AbstractBundler Class

Oracle® Fusion Middleware .NET API Reference for Oracle Coherence
14c (14.1.1.0)
F23534-02
An abstract base for processors that implement bundling strategy.
Inheritance Hierarchy

Namespace:  Tangosol.Net.Cache
Assembly:  Coherence (in Coherence.dll) Version: 14.1.1.14 (14.1.1.14)
Syntax
C#
public abstract class AbstractBundler

The AbstractBundler type exposes the following members.

Constructors
  NameDescription
Public methodAbstractBundler
Construct the bundler. By default, the timeout delay value is set to one millisecond and the auto-adjustment feature is turned on.
Top
Properties
  NameDescription
Public propertyAllowAutoAdjust
Specifies whether or not auto-adjustment is on. Default value is "true".
Public propertyDelayMillis
The timeout delay value.
Public propertySizeThreshold
The bundle size threshold value.
Public propertySyncRoot
Gets an object that can be used to synchronize access to the ICollection.
Public propertyThreadThreshold
The minimum number of threads that will trigger the bundler to switch from a pass through to a bundled mode.
Top
Methods
  NameDescription
Public methodAdjust
Adjust this Bundler's parameters according to the available statistical information.
Public methodEquals
Determines whether the specified object is equal to the current object.
(Inherited from Object.)
Protected methodFinalize
Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection.
(Inherited from Object.)
Public methodGetHashCode
Serves as the default hash function.
(Inherited from Object.)
Protected methodgetOpenBundle
Retrieve any Bundle that is currently in the open state. This method does not assume any external synchronization and as a result, a caller must double check the returned bundle open state (after synchronizing on it).
Public methodGetType
Gets the Type of the current instance.
(Inherited from Object.)
Protected methodInstantiateBundle
Instantiate a new Bundle object.
Protected methodMemberwiseClone
Creates a shallow copy of the current Object.
(Inherited from Object.)
Public methodResetStatistics
Reset this Bundler statistics.
Public methodToString
Provide a human readable description for the Bundler object (for debugging).
Public methodUpdateStatistics
Update the statistics for this Bundle.
Top
Fields
  NameDescription
Public fieldStatic memberADJUSTMENT_FREQUENCY
Frequency of the adjustment attempts. This number represents a number of iterations of the master bundle usage after which an adjustment attempt will be performed.
Protected fieldm_countThreads
A counter for the total number of threads that have started any bundle related execution. This counter is used by subclasses to reduce an impact of bundled execution for lightly loaded environments.
Protected fieldm_listBundle
A pool of Bundle objects. Note that this list never shrinks.
Protected fieldm_previousSizeThreshold
The previous bundle size threshold value.
Top
Remarks
Assume that we receive a continuous and concurrent stream of individual operations on multiple threads in parallel. Let's also assume those individual operations have relatively high latency (network or database-related) and there are functionally analogous [bulk] operations that take a collection of arguments instead of a single one without causing the latency to grow linearly, as a function of the collection size. Examples of operations and topologies that satisfy these assumptions are:
  • Get() and GetAll() methods for the INamedCache API for the partitioned cache service topology;
  • Insert() and InsertAll() methods for the INamedCache API for the partitioned cache service topology;
  • Remove() method for the INamedCache API for the partitioned cache service topology;

Under these assumptions, it's quite clear that the bundler could achieve a better utilization of system resources and better throughput if slightly delays the individual execution requests with a purpose of "bundling" them together and passing into a corresponding bulk operation. Additionally, the "bundled" request should be triggered if a bundle reaches a "preferred bundle size" threshold, eliminating a need to wait till a bundle timeout is reached.

Note Note
We assume that all bundle-able operations are idempotent and could be repeated if un-bundling is necessary due to a bundled operation failure.

See Also