Table of Contents
- Title and Copyright Information
- Preface
-
Part I Getting Started
- 1 Introduction to Coherence
- 2 Building Your First Coherence Application
-
3
Understanding Configuration
- Determining the Coherence Version
- About Coherence Configuration File Formatting
- Overview of the Default Configuration Files
- Specifying an Operational Configuration File
- Specifying a Cache Configuration File
- Specifying a POF Configuration File
- Specifying Management Configuration Files
- Disabling Schema Validation
- Understanding the XML Override Feature
- Changing Configuration Using System Properties
- 4 Extending Configuration Files
-
5
Debugging in Coherence
- Overview of Debugging in Coherence
-
Configuring Logging
- Changing the Log Level
- Changing the Log Destination
- Sending Log Messages to a File
- Changing the Log Message Format
- Setting the Logging Character Limit
- Using JDK Logging for Coherence Logs
- Mapping JDK Log Levels with Coherence Log Levels
- Using Log4j2 Logging for Coherence Logs
- Mapping Log4j2 Log Levels with Coherence Log Levels
- Using SLF4J for Coherence Logs
- Performing Remote Debugging
- Distributed Tracing
- Troubleshooting Coherence-Based Applications
-
Part II Using Coherence Clusters
- 6 Introduction to Coherence Clusters
-
7
Setting Up a Cluster
- Overview of Setting Up Clusters
- Specifying a Cluster's Name
- Specifying a Cluster Member's Identity
- Configuring Multicast Communication
- Specifying a Cluster Member's Unicast Address
- Using Well Known Addresses
- Enabling Single-Server Mode
- Configuring Death Detection
- Specifying Cluster Priorities
- Configuring Firewalls for Cluster Members
-
8
Starting and Stopping Coherence
- Using the Bootstrap API
- Using the com.tangosol.net.Coherence Class
- Using the Legacy CacheFactory Client
- Stopping Cluster Members
- Performing a Rolling Restart
- 9 Dynamically Managing Cluster Membership
-
10
Tuning TCMP Behavior
- Overview of TCMP Data Transmission
- Throttling Data Transmission
- Bundling Packets to Reduce Load
- Changing Packet Retransmission Behavior
- Configuring the Size of the Packet Buffers
- Adjusting the Maximum Size of a Packet
- Changing the Packet Speaker Volume Threshold
- Configuring the Incoming Message Handler
- Changing the TCMP Socket Provider Implementation
- Changing Transport Protocols
- Enabling CRC Validation for TMB
- 11 Using the Service Guardian
-
Part III Using Caches
- 12 Introduction to Coherence Caches
-
13
Configuring Caches
- Overview of Configuring Caches
- Defining Cache Mappings
- Defining Cache Schemes
- Using Scheme Inheritance
- Using Cache Scheme Properties
- Using Parameter Macros
- Using System Property Macros
-
14
Implementing Storage and Backing Maps
- Cache Layers
- Local Storage
- Operations
- Capacity Planning
- Using Partitioned Backing Maps
- Using the Elastic Data Feature to Store Data
- Using Asynchronous Backup
- Using the Read Locator
- Scheduling Backups
- Using Asynchronous Persistence
- Using Persistent Backups
- Using Delta Backup
- Integrating Caffeine
-
15
Caching Data Sources
- Overview of Caching Data Sources
- Selecting a Cache Strategy
- Creating a Cache Store Implementation
- Plugging in a Cache Store Implementation
- Sample Cache Store Implementation
- Sample Controllable Cache Store Implementation
- Implementation Considerations
- 16 Serialization Paged Cache
- 17 Using Quorum
- 18 Cache Configurations by Example
- 19 Using Cache Configuration Override
- Part IV Using Topics
-
Part V Performing Data Grid Operations
- 24 Introduction to Coherence Programming
-
25
Performing Basic Cache Operations
- Overview of the NamedMap API
- Getting a Cache Instance
- Performing Cache Put Operations
- Performing Cache Get Operations
- Performing Cache Remove Operations
- Using Default Map Operations
- Pre-Loading a Cache
- Clearing Caches
- Releasing Caches
- Destroying Caches
- Closing Sessions
- Performing NamedMap Operations Asynchronously
- Using NamedMap Type Checking
-
26
Performing Basic Topic Publish and Subscribe
Operations
- Overview of Topics API
- Getting a Topic Instance
- Using NamedTopic Type Checking
- Publishing to a Topic
- Subscribing Directly to a Topic
- Releasing Subscriber Resources
- Subscribing to a Subscriber Group
- Subscriber Groups for a NamedTopic
- Destroying a Topic’s Subscriber Group
- Committing Messages
- Managing the Resources Used by a Topic
- Understanding Topics Flow Control
- Managing the Publisher Flow Control to Place Upper Bound on Topics Storage
-
27
Using Portable Object Format
- Overview of POF Serialization
- About Portable Types
- Using the Advanced POF Serialization Options
- Serializing Keys Using POF
- Using Protobuf With POF
-
28
Querying Data in a Cache
- Query Overview
- Query Concepts
- Performing Queries
- Efficient Processing of Filter Results
- Using Query Indexes
- Performing Batch Queries
- Using Sorted Views
- Performing Queries on Multi-Value Attributes
- Using Chained Extractors
- Options to Skip Query Result Consistency Check
- Evaluating Query Cost and Effectiveness
-
29
Using Continuous Query Caching
- Overview of Using Continuous Query Caching
- Understanding Use Cases for Continuous Query Caching
- Understanding the Continuous Query Cache Implementation
- Constructing a Continuous Query Cache
- Cleaning up the resources associated with a ContinuousQueryCache
- Caching only keys, or caching both keys and values
- Listening to a Continuous Query Cache
- Making a Continuous Query Cache Read-Only
-
30
Processing Data In a Cache
- Overview of Processing Data In a Cache
- Using Agents for Targeted, Parallel and Query-Based Processing
- Performing Data Grid Aggregation
- Performing Data Grid Aggregation Using Streams
- Performing Node-Based Processing
-
31
Using Map Events
- Overview of Map Events
- Signing Up for All Events
- Using an Inner Class as a MapListener
- Using Lambda Expressions to Add Map Listeners
- Configuring a MapListener For a Cache
- Signing Up For Events On Specific Identities
- Filtering Events
- Using Lite Events
- Listening to Queries
- Using Synthetic Events
- Listening to Backing Map Events
- Using Synchronous Event Listeners
- Using Durable Events (Experimental)
- 32 Controlling Map Operations with Triggers
-
33
Using Live Events
- Overview of Live Events
- Understanding Live Event Types
- Handling Live Events
-
34
Using Coherence Query Language
- Understanding Coherence Query Language Syntax
- Using the CohQL Command-Line Tool
- Building Filters in Java Programs
-
Additional Coherence Query Language Examples
- Simple SELECT * FROM Statements that Highlight Filters
- Complex Queries that Feature Projection, Aggregation, and Grouping
- UPDATE Examples
- Key and Value Pseudo-Function Examples
- Working with Java Objects (POJO’s)
- Working with Java Record Class
- Working with JSON Objects
- Using Extended Language Features
-
35
Performing Transactions
- Overview of Transactions
- Using Explicit Locking for Data Concurrency
- Using Entry Processors for Data Concurrency
-
Using the Transaction Framework API
- Defining Transactional Caches
- Performing Cache Operations within a Transaction
- Creating Transactional Connections
- Using Transactional Connections
- Using the OptimisticNamedCache Interface
- Configuring POF When Performing Transactions
- Configuring Transactional Storage Capacity
- Performing Transactions from Java Extend Clients
- Viewing Transaction Management Information
- Using the Coherence Resource Adapter
- 36 Working with Partitions
- 37 Managing Thread Execution
- 38 Constraints on Re-Entrant Calls
- 39 Using Timeout with Cache Operations
- 40 Using the Repository API
- 41 Implementing Concurrency in a Distributed Environment
-
42
Using Contexts and Dependency
Injection
- Using CDI
- Injecting Coherence Objects into CDI Beans
- Injecting CDI Beans into Coherence-Managed Objects
- Injecting CDI Beans into Transient Objects
- Using the FilterBinding Annotations
- Using ExtractorBinding Annotations
- Using MapEventTransformerBinding Annotations
- Using CDI Response Caching
-
Part VI Using the Coherence JCache Implementation
- 43 Introduction to Coherence JCache
- 44 Building Your First Coherence JCache Application
-
45
Performing Basic Coherence JCache Tasks
- Specifying Coherence as the JCache Provider
- Creating Coherence JCache Caches
- Configuring Coherence JCache Caches
- Performing Cache Operations
- Using Read-Through and Write-Through Caching
- Configuring a JCache POF Configuration file
- Viewing JCache Management Information
- 46 Using JCache Events
- 47 Processing JCache Entries
- Part VII Developing and Running Polyglot Coherence Applications
-
Part VIII Building Upgradable Coherence Applications
-
49
Upgrade Considerations
- Application Recompilation
- Serialization
- Cache Keys and Values
- Entry Processors
- Filters
- Aggregators
- Value Extractors
- Use of Lambdas
- Topics
- Cache Loaders and Cache Stores
- Coherence Clients
- Cache Configuration Changes
- Operational Configuration Changes
- Security and SSL/TLS
- Persistence
- Federation
- Executor Service
-
49
Upgrade Considerations
-
A
Operational Configuration Elements
- Operational Deployment Descriptor
- Operational Override File
-
Operational Configuration Element Reference
- access-controller
- active-active
- active-passive
- address-provider
- address-providers
- authorized-hosts
- cache-factory-builder-config
- callback-handler
- central-replication
- cluster-config
- cluster-quorum-policy
- coherence
- configurable-cache-factory-config
- custom-topology
- federation-config
- flashjournal-manager
- flow-control
- group
- groups
- host-range
- hub-spoke
- identity-asserter
- identity-manager
- identity-transformer
- incoming-message-handler
- init-param
- init-params
- instance
- interceptor
- interceptors
- journaling-config
- key-store
- license-config
- logging-config
- management-config
- mbean
- mbeans
- mbean-filter
- member-identity
- multicast-listener
- name-service-addresses
- notification-queueing
- outgoing-message-handler
- outstanding-packets
- packet-buffer
- packet-bundling
- packet-delivery
- packet-publisher
- packet-size
- packet-speaker
- participant
- participants
- participant-destination
- participant-destinations
- password-provider
- password-providers
- pause-detection
- persistence-environment
- persistence-environments
- provider
- ramjournal-manager
- remote-addresses
- reporter
- security-config
- serializer
- serializers
-
service
-
Initialization Parameter Settings
- DistributedCache Service Parameters
- ReplicatedCache Service Parameters
- OptimisticCache Service Parameters
- Invocation Service Parameters
- LocalCache Service Parameters
- Proxy Service Parameters
- RemoteCache Service Parameters
- RemoteInvocation Service Parameters
- NameService Parameters
- RemoteNameService Parameters
- FederatedCache Service Parameters
-
Initialization Parameter Settings
- service-guardian
- services
- shutdown-listener
- snapshot-archivers
- socket-address
- socket-provider
- socket-providers
- ssl
- storage-authorizer
- storage-authorizers
- tcp-ring-listener
- topology-definitions
- tracing-config
- traffic-jam
- trust-manager
- unicast-listener
- volume-threshold
- well-known-addresses
- Operational Configuration Attribute Reference
-
B
Cache Configuration Elements
- Cache Configuration Deployment Descriptor
-
Cache Configuration Element Reference
- acceptor-config
- address-provider
- async-store-manager
- authorized-hosts
- back-scheme
- backing-map-scheme
- backup-storage
- bdb-store-manager
- bundle-config
- cache-config
- cache-mapping
- cache-service-proxy
- cachestore-scheme
- caching-scheme-mapping
- caching-schemes
- class-scheme
- custom-store-manager
- defaults
- distributed-scheme
- external-scheme
- federated-scheme
- flashjournal-scheme
- front-scheme
- grpc-acceptor
- http-acceptor
- identity-manager
- incoming-message-handler
- initiator-config
- init-param
- init-params
- instance
- interceptor
- interceptors
- invocation-scheme
- invocation-service-proxy
- key-associator
- key-partitioning
- key-store
- listener
- local-address
- local-scheme
- memcached-acceptor
- name-service-addresses
- near-scheme
- nio-file-manager
- operation-bundling
- optimistic-scheme
- outgoing-message-handler
- overflow-scheme
- page-size
- paged-topic-scheme
- paged-external-scheme
- partitioned-quorum-policy-scheme
- partition-listener
- persistence
- provider
- proxy-config
- proxy-quorum-policy-scheme
- proxy-scheme
- ramjournal-scheme
- read-write-backing-map-scheme
- remote-addresses
- remote-cache-scheme
- remote-invocation-scheme
- replicated-scheme
- resource-config
- serializer
- socket-address
- socket-provider
- ssl
- tcp-acceptor
- tcp-initiator
- topologies
- topology
- transactional-scheme
- trust-manager
- view-scheme
- Cache Configuration Attribute Reference
- C Topic Configuration Element Reference
- D POF User Type Configuration Elements
- E System Property Overrides
- F The PIF-POF Binary Format