web-2/wildfly/docs/schema/jboss-as-infinispan_13_0.xsd

1544 lines
73 KiB
XML
Raw Permalink Normal View History

2024-10-15 03:01:27 +03:00
<?xml version="1.0" encoding="UTF-8"?>
<!--
~ Copyright The WildFly Authors
~ SPDX-License-Identifier: Apache-2.0
-->
<xs:schema targetNamespace="urn:jboss:domain:infinispan:13.0"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="urn:jboss:domain:infinispan:13.0"
elementFormDefault="qualified"
attributeFormDefault="unqualified"
version="13.0">
<xs:element name="subsystem" type="tns:subsystem">
<xs:annotation>
<xs:documentation>Enumerates the cache containers available to the registry.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:complexType name="subsystem">
<xs:choice maxOccurs="unbounded">
<xs:element name="cache-container" type="tns:cache-container">
<xs:annotation>
<xs:documentation>Defines an embedded cache container.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="remote-cache-container" type="tns:remote-cache-container">
<xs:annotation>
<xs:documentation>Defines a remote cache container.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:choice>
</xs:complexType>
<xs:complexType name="cache-container">
<xs:sequence>
<xs:element name="transport" type="tns:transport" minOccurs="0">
<xs:annotation>
<xs:documentation>Overrides the transport characteristics for this cache container.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="async-operations-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used for asynchronous operations.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="blocking-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used for blocking operations.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="listener-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used for asynchronous cache listener notifications.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="non-blocking-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used for non-blocking operations.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="persistence-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used for interacting with the persistent store.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="remote-command-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used to execute remote commands.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="state-transfer-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used for for state transfer.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="transport-thread-pool" type="tns:thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a thread pool used for asynchronous transport communication.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="expiration-thread-pool" type="tns:scheduled-thread-pool" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Defines a scheduled thread pool used for expiration.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:choice maxOccurs="unbounded">
<xs:element name="local-cache" type="tns:local-cache">
<xs:annotation>
<xs:documentation>Defines a local mode cache.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="replicated-cache" type="tns:replicated-cache">
<xs:annotation>
<xs:documentation>Defines a replication mode cache.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="invalidation-cache" type="tns:invalidation-cache">
<xs:annotation>
<xs:documentation>Defines an invalidation mode cache.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="distributed-cache" type="tns:distributed-cache">
<xs:annotation>
<xs:documentation>Defines a distribution mode cache.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="scattered-cache" type="tns:scattered-cache">
<xs:annotation>
<xs:documentation>Defines a scattered mode cache.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:choice>
</xs:sequence>
<xs:attribute name="name" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>Uniquely identifies this cache container.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="aliases" type="tns:list">
<xs:annotation>
<xs:documentation>A set of aliases by which this cache container may also be referenced.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="default-cache" type="xs:string" use="optional">
<xs:annotation>
<xs:documentation>Indicates the default cache for this cache container.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="marshaller" type="tns:marshaller">
<xs:annotation>
<xs:documentation>Defines the marshalling implementation used to marshal cache entries.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="modules" type="tns:list" default="org.jboss.as.clustering.infinispan">
<xs:annotation>
<xs:documentation>Defines the set of modules associated with this cache container.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="statistics-enabled" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>Determines whether or not the cache container should collect statistics. Keep disabled for optimal performance.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="transport">
<xs:attribute name="channel" type="xs:string">
<xs:annotation>
<xs:documentation>Defines the channel used for this transport.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="stack" type="xs:string">
<xs:annotation>
<xs:documentation>Defines the jgroups stack used by the transport.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="lock-timeout" type="xs:long" default="240000">
<xs:annotation>
<xs:documentation>
Infinispan uses a distributed lock to maintain a coherent transaction log during state transfer or rehashing, which means that only one cache can be doing state transfer or rehashing at the same time.
This constraint is in place because more than one cache could be involved in a transaction.
This timeout controls the time to wait to acquire acquire a lock on the distributed lock.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="cache" abstract="true">
<xs:sequence>
<xs:element name="locking" type="tns:locking" minOccurs="0">
<xs:annotation>
<xs:documentation>The locking configuration of the cache.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="transaction" type="tns:transaction" minOccurs="0">
<xs:annotation>
<xs:documentation>The cache transaction configuration.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:choice minOccurs="0">
<xs:element name="heap-memory" type="tns:heap-memory">
<xs:annotation>
<xs:documentation>The cache memory configuration.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="off-heap-memory" type="tns:off-heap-memory">
<xs:annotation>
<xs:documentation>The cache memory configuration.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:choice>
<xs:element name="expiration" type="tns:expiration" minOccurs="0">
<xs:annotation>
<xs:documentation>The cache expiration configuration.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:choice minOccurs="0">
<xs:element name="store" type="tns:custom-store">
<xs:annotation>
<xs:documentation>Defines a custom cache store.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="file-store" type="tns:file-store">
<xs:annotation>
<xs:documentation>Defines a file-based cache store.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:choice minOccurs="0">
<xs:element name="jdbc-store" type="tns:jdbc-store">
<xs:annotation>
<xs:documentation>Defines a database cache store accessed via JDBC using string-based keys.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="binary-keyed-jdbc-store" type="tns:binary-keyed-jdbc-store">
<xs:annotation>
<xs:documentation>Defines a database cache store accessed via JDBC using binary-based keys. Warning: This option has been deprecated, please use jdbc-store instead</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="mixed-keyed-jdbc-store" type="tns:mixed-keyed-jdbc-store">
<xs:annotation>
<xs:documentation>
Defines a database cache store accessed via JDBC using mixed string and binary-based keys.
Warning: This option has been deprecated, please use jdbc-store instead.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:choice>
<xs:element name="remote-store" type="tns:remote-store">
<xs:annotation>
<xs:documentation>
Defines a remote cache store accessed via HotRod.
Nested properties will be treated as HotRod client properties.
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="hotrod-store" type="tns:hotrod-store">
<xs:annotation>
<xs:documentation>
HotRod-based store using Infinispan Server instance to store data.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:choice>
</xs:sequence>
<xs:attribute name="name" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>Uniquely identifies this cache within its cache container.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="modules" type="tns:list">
<xs:annotation>
<xs:documentation>
Defines the set of modules associated with cache, if different from the enclosing cache container.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="statistics-enabled" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>Determines whether or not the cache should collect statistics. Keep disabled for optimal performance.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="local-cache">
<xs:complexContent>
<xs:extension base="tns:cache"/>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="locking">
<xs:attribute name="isolation" type="tns:isolation" default="READ_COMMITTED">
<xs:annotation>
<xs:documentation>Sets the cache locking isolation level.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="striping" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>
If true, a pool of shared locks is maintained for all entries that need to be locked.
Otherwise, a lock is created per entry in the cache.
Lock striping helps control memory footprint but may reduce concurrency in the system.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="acquire-timeout" type="xs:long" default="15000">
<xs:annotation>
<xs:documentation>Maximum time to attempt a particular lock acquisition.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="concurrency-level" type="xs:int" default="1000">
<xs:annotation>
<xs:documentation>Concurrency level for lock containers. Adjust this value according to the number of concurrent threads interacting with Infinispan.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="transaction">
<xs:attribute name="mode" type="tns:transaction-mode" default="NONE">
<xs:annotation>
<xs:documentation>Defines the transaction mode of the cache.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="stop-timeout" type="xs:long" default="10000">
<xs:annotation>
<xs:documentation>
If there are any ongoing transactions when a cache is stopped, Infinispan waits for ongoing remote and local transactions to finish.
The amount of time to wait for is defined by the cache stop timeout.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="locking" type="tns:locking-mode" default="PESSIMISTIC">
<xs:annotation>
<xs:documentation>The locking mode for this cache, one of OPTIMISTIC or PESSIMISTIC.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="complete-timeout" type="xs:long" default="60000">
<xs:annotation>
<xs:documentation>
The default duration (in ms) after which idle transactions are rolled back.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="memory">
<xs:attribute name="size" type="xs:long">
<xs:annotation>
<xs:documentation>Maximum size of this cache.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="heap-memory">
<xs:complexContent>
<xs:extension base="tns:memory">
<xs:attribute name="size-unit" type="tns:size-unit" fixed="ENTRIES">
<xs:annotation>
<xs:documentation>Describes the unit of measurement for the size attribute.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="off-heap-memory">
<xs:complexContent>
<xs:extension base="tns:memory">
<xs:attribute name="size-unit" type="tns:size-unit" default="ENTRIES">
<xs:annotation>
<xs:documentation>Describes the unit of measurement for the size attribute.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="expiration">
<xs:attribute name="max-idle" type="xs:long">
<xs:annotation>
<xs:documentation>
Maximum idle time a cache entry will be maintained in the cache, in milliseconds.
If the idle time is exceeded, the entry will be expired cluster-wide.
If undefined, idle cache entries will not auto-expire.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="lifespan" type="xs:long">
<xs:annotation>
<xs:documentation>
Maximum lifespan of a cache entry, after which the entry is expired cluster-wide, in milliseconds.
If undefined, cache entries will not auto-expire.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="interval" type="xs:long" default="5000">
<xs:annotation>
<xs:documentation>
Interval (in milliseconds) between subsequent runs to purge expired entries from memory and any cache stores.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="clustered-cache" abstract="true">
<xs:complexContent>
<xs:extension base="tns:cache">
<xs:attribute name="remote-timeout" type="xs:long" default="10000">
<xs:annotation>
<xs:documentation>The timeout (in ms) used to wait for an acknowledgment when making a remote call, after which the call is aborted and an exception is thrown.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="invalidation-cache">
<xs:complexContent>
<xs:extension base="tns:clustered-cache"/>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="shared-state-cache" abstract="true">
<xs:complexContent>
<xs:extension base="tns:clustered-cache">
<xs:sequence>
<xs:element name="partition-handling" type="tns:partition-handling" minOccurs="0">
<xs:annotation>
<xs:documentation>The partition handling configuration for distributed and replicated caches.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="state-transfer" type="tns:state-transfer" minOccurs="0">
<xs:annotation>
<xs:documentation>The state transfer configuration for distributed and replicated caches.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:sequence minOccurs="0">
<xs:element name="backups" type="tns:backups" minOccurs="0">
<xs:annotation>
<xs:documentation>A list of backup sites for this cache (for use with cross-site replication).</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
</xs:sequence>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="replicated-cache">
<xs:complexContent>
<xs:extension base="tns:shared-state-cache"/>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="segmented-cache" abstract="true">
<xs:complexContent>
<xs:extension base="tns:shared-state-cache">
<xs:attribute name="segments" type="xs:int" default="256">
<xs:annotation>
<xs:documentation>Number of hash space segments (per cluster).</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="consistent-hash-strategy" type="tns:consistent-hash-strategy" default="INTER_CACHE">
<xs:annotation>
<xs:documentation>
Defines the consistent hash strategy for the cache.
This determines the consistent hash factory to use for generating the consistent hash.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="distributed-cache">
<xs:complexContent>
<xs:extension base="tns:segmented-cache">
<xs:attribute name="owners" type="xs:int" default="2">
<xs:annotation>
<xs:documentation>Number of cluster-wide replicas for each cache entry.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="l1-lifespan" type="xs:long" default="0">
<xs:annotation>
<xs:documentation>Maximum lifespan in milliseconds of an entry placed in the L1 cache.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="capacity-factor" type="xs:float" default="1.0">
<xs:annotation>
<xs:documentation>Controls the proportion of entries that will reside on the local node, compared to the other nodes in the cluster.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="scattered-cache">
<xs:complexContent>
<xs:extension base="tns:segmented-cache">
<xs:attribute name="bias-lifespan" type="xs:long" default="300000">
<xs:annotation>
<xs:documentation>When greater than zero, specifies the duration (in ms) that a cache entry will be cached on a non-owner following a write operation.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="invalidation-batch-size" type="xs:int" default="128">
<xs:annotation>
<xs:documentation>The threshold after which batched invalidations are sent.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="store" abstract="true">
<xs:sequence>
<xs:element name="write-behind" type="tns:write-behind" minOccurs="0" maxOccurs="1">
<xs:annotation>
<xs:documentation>Configures a cache store as write-behind instead of write-through.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="property" type="tns:property" minOccurs="0" maxOccurs="unbounded">
<xs:annotation>
<xs:documentation>A cache store property with name and value.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
<xs:attribute name="max-batch-size" type="xs:int" default="100">
<xs:annotation>
<xs:documentation>
The maximum size of a batch to be inserted/deleted from the store.
If the value is less than one, then no upper limit is placed on the number of operations in a batch.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="shared" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>
This setting should be set to true when multiple cache instances share the same cache store, e.g. multiple nodes in a cluster using a JDBC-based CacheStore pointing to the same shared database.
Setting this to true avoids multiple cache instances writing the same modification multiple times.
If enabled, only the node where the modification originated will write to the cache store.
If disabled, each individual cache reacts to a potential remote update by storing the data to the cache store.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="preload" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>
If true, when the cache starts, data stored in the cache store will be pre-loaded into memory.
This is particularly useful when data in the cache store will be needed immediately after startup and you want to avoid cache operations being delayed as a result of loading this data lazily.
Can be used to provide a 'warm-cache' on startup, however there is a performance penalty as startup time is affected by this process.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="passivation" type="xs:boolean" default="true">
<xs:annotation>
<xs:documentation>
If true, data is only written to the cache store when it is evicted from memory, a phenomenon known as 'passivation'.
Next time the data is requested, it will be 'activated' which means that data will be brought back to memory and removed from the persistent store.
If false, the cache store contains a copy of the contents in memory, so writes to cache result in cache store writes.
This essentially gives you a 'write-through' configuration.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="fetch-state" type="xs:boolean" default="true">
<xs:annotation>
<xs:documentation>If true, fetch persistent state when joining a cluster.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="purge" type="xs:boolean" default="true">
<xs:annotation>
<xs:documentation>If true, purges this cache store when it starts up.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="singleton" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>Deprecated. This attribute does nothing an will be removed in a future release.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="write-behind">
<xs:attribute name="modification-queue-size" type="xs:int" default="1024">
<xs:annotation>
<xs:documentation>
Maximum number of entries in the asynchronous queue. When the queue is full, the store becomes write-through.
until it can accept new entries
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="thread-pool-size" type="xs:int" default="1">
<xs:annotation>
<xs:documentation>
Size of the thread pool whose threads are responsible for applying the modifications to the cache store.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="custom-store">
<xs:complexContent>
<xs:extension base="tns:store">
<xs:attribute name="class" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>The class name of the cache store implementation.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="file-store">
<xs:complexContent>
<xs:extension base="tns:store">
<xs:attribute name="relative-to" type="xs:string" default="jboss.server.data.dir">
<xs:annotation>
<xs:documentation>The base directory in which to store the cache state.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="path" type="xs:string">
<xs:annotation>
<xs:documentation>
The path within "relative-to" in which to store the cache state.
If undefined, the path defaults to the cache container name.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="remote-store">
<xs:complexContent>
<xs:extension base="tns:store">
<xs:attribute name="remote-servers" type="tns:list" use="required">
<xs:annotation>
<xs:documentation>A list of outbound socket bindings.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="cache" type="xs:string">
<xs:annotation>
<xs:documentation>The name of the remote cache. If undefined, the default cache will be used.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="socket-timeout" type="xs:long" default="60000">
<xs:annotation>
<xs:documentation>
Enable/disable SO_TIMEOUT on socket connections to remote Hot Rod servers with the specified timeout, in milliseconds.
A timeout of zero is interpreted as an infinite timeout.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="tcp-no-delay" type="xs:boolean" default="true">
<xs:annotation>
<xs:documentation>
Enable/disable TCP_NODELAY on socket connections to remote Hot Rod servers.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="hotrod-store">
<xs:complexContent>
<xs:extension base="tns:store">
<xs:attribute name="cache-configuration" type="xs:string">
<xs:annotation>
<xs:documentation>
Name of the cache configuration template defined in Infinispan Server to create caches from.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="remote-cache-container" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>
Reference to a container-managed remote-cache-container.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="abstract-jdbc-store">
<xs:complexContent>
<xs:extension base="tns:store">
<xs:attribute name="data-source" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>References the pool name of a data source.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="dialect" type="tns:dialect" use="optional">
<xs:annotation>
<xs:documentation>Defines the JDBC dialect.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="jdbc-store">
<xs:complexContent>
<xs:extension base="tns:abstract-jdbc-store">
<xs:sequence>
<xs:element name="table" type="tns:string-keyed-table" minOccurs="0">
<xs:annotation>
<xs:documentation>
Defines the table used to store cache entries.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="binary-keyed-jdbc-store">
<xs:complexContent>
<xs:extension base="tns:abstract-jdbc-store">
<xs:sequence>
<xs:element name="binary-keyed-table" type="tns:binary-keyed-table" minOccurs="0">
<xs:annotation>
<xs:documentation>
Defines the table used to store cache buckets.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="mixed-keyed-jdbc-store">
<xs:complexContent>
<xs:extension base="tns:abstract-jdbc-store">
<xs:sequence>
<xs:element name="binary-keyed-table" type="tns:binary-keyed-table" minOccurs="0">
<xs:annotation>
<xs:documentation>
Defines the table used to store cache buckets.
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="string-keyed-table" type="tns:string-keyed-table" minOccurs="0">
<xs:annotation>
<xs:documentation>
Defines the table used to store cache entries.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="string-keyed-table">
<xs:complexContent>
<xs:extension base="tns:table">
<xs:attribute name="prefix" type="xs:string" default="ispn_entry">
<xs:annotation>
<xs:documentation>Defines the prefix prepended to the cache name used when composing the name of the cache entry table.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="binary-keyed-table">
<xs:complexContent>
<xs:extension base="tns:table">
<xs:attribute name="prefix" type="xs:string" default="ispn_bucket">
<xs:annotation>
<xs:documentation>Defines the prefix prepended to the cache name used when composing the name of the cache bucket table.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:complexContent>
</xs:complexType>
<xs:complexType name="table">
<xs:sequence>
<xs:element name="id-column" type="tns:id-column" minOccurs="0">
<xs:annotation>
<xs:documentation>Defines the column in which to store the cache key or bucket id.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="data-column" type="tns:data-column" minOccurs="0">
<xs:annotation>
<xs:documentation>Defines the column in which to store the cache entry or bucket.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="segment-column" type="tns:segment-column" minOccurs="0">
<xs:annotation>
<xs:documentation>Defines the column in which to store the entry segment.</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="timestamp-column" type="tns:timestamp-column" minOccurs="0">
<xs:annotation>
<xs:documentation>Defines the column in which to store the timestamp of the cache entry or bucket.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
<xs:attribute name="fetch-size" type="xs:int" default="100">
<xs:annotation>
<xs:documentation>The fetch size used when querying from this table. Used to avoid heap memory exhaustion when query is large.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="create-on-start" type="xs:boolean" default="true">
<xs:annotation>
<xs:documentation>Indicates whether the store should create this database table when the cache starts.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="drop-on-stop" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>Indicates whether the store should drop this database table when the cache stops.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="id-column">
<xs:attribute name="name" type="xs:string" default="id">
<xs:annotation>
<xs:documentation>The name of the column used to store the cache key.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="type" type="xs:string" default="VARCHAR">
<xs:annotation>
<xs:documentation>The type of the column used to store the cache key.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="data-column">
<xs:attribute name="name" type="xs:string" default="datum">
<xs:annotation>
<xs:documentation>The name of the column used to store the cache entry.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="type" type="xs:string" default="BINARY">
<xs:annotation>
<xs:documentation>The type of the column used to store the cache entry.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="segment-column">
<xs:attribute name="name" type="xs:string" default="segment">
<xs:annotation>
<xs:documentation>The name of the column used to store the cache entry segment.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="type" type="xs:string" default="INTEGER">
<xs:annotation>
<xs:documentation>The type of the column used to store the cache entry segment.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="timestamp-column">
<xs:attribute name="name" type="xs:string" default="version">
<xs:annotation>
<xs:documentation>The name of the column used to store the cache entry timestamp.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="type" type="xs:string" default="BIGINT">
<xs:annotation>
<xs:documentation>The type of the column used to store the cache entry timestamp.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="partition-handling">
<xs:attribute name="enabled" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>If enabled, the cache will enter degraded mode upon detecting a network partition that threatens the integrity of the cache.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="state-transfer">
<xs:attribute name="timeout" type="xs:long" default="240000">
<xs:annotation>
<xs:documentation>
The maximum amount of time (in ms) to wait for state from neighboring caches, before throwing an exception and aborting startup.
A timeout of 0 means the cache will be available immediately after joining, and initial state transfer is non-blocking.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="chunk-size" type="xs:integer" default="512">
<xs:annotation>
<xs:documentation>The number of cache entries to batch in each transfer.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="backups">
<xs:sequence>
<xs:element name="backup" type="tns:backup" maxOccurs="unbounded">
<xs:annotation>
<xs:documentation>A backup site for this cache.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
</xs:complexType>
<xs:complexType name="backup">
<xs:sequence>
<xs:element name="take-offline" type="tns:take-offline" minOccurs="0">
<xs:annotation>
<xs:documentation>Control when to take this backup site offline.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
<xs:attribute name="site" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>The name of this remote site.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="strategy" type="tns:mode" default="ASYNC">
<xs:annotation>
<xs:documentation>The backup strategy for this cache.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="failure-policy" type="tns:backup-failure-policy" default="WARN">
<xs:annotation>
<xs:documentation>The policy to follow when connectivity to the backup site fails.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="timeout" type="xs:long" default="10000">
<xs:annotation>
<xs:documentation>The timeout for replicating to the backup site.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="enabled" type="xs:boolean" default="true">
<xs:annotation>
<xs:documentation>Indicates whether or not this backup site is enabled.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="backup-for">
<xs:attribute name="remote-cache" type="xs:string">
<xs:annotation>
<xs:documentation>The name of the remote cache for which this cache acts as a backup</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="remote-site" type="xs:string">
<xs:annotation>
<xs:documentation>The site of the remote cache for which this cache acts as a backup.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="take-offline">
<xs:attribute name="after-failures" type="xs:int" default="0">
<xs:annotation>
<xs:documentation>Indicates the number of failures after which this backup site should go offline.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="min-wait" type="xs:long" default="0">
<xs:annotation>
<xs:documentation>Indicates the minimum time (in milliseconds) to wait after the max number of failures is reached, after which this backup site should go offline.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="property">
<xs:simpleContent>
<xs:extension base="xs:string">
<xs:attribute name="name" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>Defines the name of a property.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:extension>
</xs:simpleContent>
</xs:complexType>
<xs:simpleType name="isolation">
<xs:restriction base="xs:token">
<xs:enumeration value="NONE">
<xs:annotation>
<xs:documentation>
No locking isolation will be performed. This is only valid in local mode. In clustered mode, READ_COMMITTED will be used instead.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="READ_UNCOMMITTED">
<xs:annotation>
<xs:documentation>
Unsupported. Actually configures READ_COMMITTED.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="READ_COMMITTED">
<xs:annotation>
<xs:documentation>
Read committed is an isolation level that guarantees that any data read is committed at the moment it is read. However, depending on the outcome of other transactions, successive reads may return different results.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="REPEATABLE_READ">
<xs:annotation>
<xs:documentation>
Repeatable read is an isolation level that guarantees that any data read is committed at the moment it is read and that, within a transaction, successive reads will always return the same data.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="SERIALIZABLE">
<xs:annotation>
<xs:documentation>
Unsupported. Actually configures REPEATABLE_READ.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="transaction-mode">
<xs:restriction base="xs:token">
<xs:enumeration value="NONE">
<xs:annotation>
<xs:documentation>Cache will be non-transactional.</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="BATCH">
<xs:annotation>
<xs:documentation>Cache will support batching of operations.</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="NON_XA">
<xs:annotation>
<xs:documentation>Cache will enlist within transactions as a javax.transaction.Synchronization</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="NON_DURABLE_XA">
<xs:annotation>
<xs:documentation>Cache will enlist within transactions as a javax.transaction.xa.XAResource, without recovery.</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="FULL_XA">
<xs:annotation>
<xs:documentation>Cache will enlist within transactions as a javax.transaction.xa.XAResource, with recovery.</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="eviction-type">
<xs:restriction base="xs:token">
<xs:enumeration value="COUNT">
<xs:annotation>
<xs:documentation>
Evicts the oldest entries when the number of cache entries exceeds the specified size.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="MEMORY">
<xs:annotation>
<xs:documentation>
Evicts the oldest entries when the total memory size of cache entries exceeds the specified size.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="mode">
<xs:restriction base="xs:token">
<xs:enumeration value="ASYNC">
<xs:annotation>
<xs:documentation>
Enables asynchronous mode.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="SYNC">
<xs:annotation>
<xs:documentation>
Enables synchronous mode.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="locking-mode">
<xs:restriction base="xs:token">
<xs:enumeration value="OPTIMISTIC">
<xs:annotation>
<xs:documentation>
Enables Optimistic locking.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PESSIMISTIC">
<xs:annotation>
<xs:documentation>
Enables Pessimistic locking.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="list">
<xs:list itemType="xs:string"/>
</xs:simpleType>
<xs:simpleType name="backup-failure-policy">
<xs:restriction base="xs:token">
<xs:enumeration value="IGNORE">
<xs:annotation>
<xs:documentation>
Ignore backup failures.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="WARN">
<xs:annotation>
<xs:documentation>
Warn of backup failures.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="FAIL">
<xs:annotation>
<xs:documentation>
Fail local operations when a backup failure occurs.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="dialect">
<xs:restriction base="xs:token">
<xs:enumeration value="ACCESS"/>
<xs:enumeration value="DB2"/>
<xs:enumeration value="DB2_390"/>
<xs:enumeration value="DERBY"/>
<xs:enumeration value="FIREBIRD"/>
<xs:enumeration value="H2"/>
<xs:enumeration value="HSQL"/>
<xs:enumeration value="INFORMIX"/>
<xs:enumeration value="INTERBASE"/>
<xs:enumeration value="MARIA_DB"/>
<xs:enumeration value="MYSQL"/>
<xs:enumeration value="ORACLE"/>
<xs:enumeration value="POSTGRES"/>
<xs:enumeration value="SQL_SERVER"/>
<xs:enumeration value="SQLITE"/>
<xs:enumeration value="SYBASE"/>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="consistent-hash-strategy">
<xs:restriction base="xs:token">
<xs:enumeration value="INTER_CACHE">
<xs:annotation>
<xs:documentation>
A given cache key will have the same consistent hash on every node on any cache with the same topology.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="INTRA_CACHE">
<xs:annotation>
<xs:documentation>
A given cache key will have the same consistent hash on every node within a given cache with the same topology.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="size-unit">
<xs:restriction base="xs:token">
<xs:enumeration value="ENTRIES"/>
<xs:enumeration value="BYTES"/>
<xs:enumeration value="KB"/>
<xs:enumeration value="KiB"/>
<xs:enumeration value="MB"/>
<xs:enumeration value="MiB"/>
<xs:enumeration value="GB"/>
<xs:enumeration value="GiB"/>
<xs:enumeration value="GB"/>
<xs:enumeration value="GiB"/>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="marshaller">
<xs:restriction base="xs:token">
<xs:enumeration value="LEGACY">
<xs:annotation>
<xs:documentation>Deprecated. Selects the marshaller dynamically based on the associated modules.</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="JBOSS">
<xs:annotation>
<xs:documentation>Marshals cache entries using JBoss Marshalling.</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PROTOSTREAM">
<xs:annotation>
<xs:documentation>Marshals cache entries using ProtoStream.</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:complexType name="thread-pool">
<xs:attribute name="min-threads" type="xs:int" use="optional">
<xs:annotation>
<xs:documentation>Minimum thread pool size for the thread pool.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="max-threads" type="xs:int" use="optional">
<xs:annotation>
<xs:documentation>Maximum thread pool size for the thread pool.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="queue-length" type="xs:int" use="optional">
<xs:annotation>
<xs:documentation>Maximum queue length for the thread pool.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="keepalive-time" type="xs:long" use="optional">
<xs:annotation>
<xs:documentation>Timeout in milliseconds to remove idle thread from the pool.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="scheduled-thread-pool">
<xs:attribute name="min-threads" type="xs:int" use="optional">
<xs:annotation>
<xs:documentation>Fixed thread pool size for the scheduled thread pool.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="keepalive-time" type="xs:long" use="optional">
<xs:annotation>
<xs:documentation>Timeout in milliseconds to remove idle thread from the scheduled thread pool.</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="remote-cache-container">
<xs:sequence>
<xs:element name="async-thread-pool" type="tns:thread-pool" minOccurs="0">
<xs:annotation>
<xs:documentation>
Configuration for the executor service used for asynchronous work on the Transport,
including asynchronous marshalling and Cache async operations such as RemoteCache.putAsync().
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="connection-pool" type="tns:connection-pool" minOccurs="0">
<xs:annotation>
<xs:documentation>
Configuration of the connection pool.
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="invalidation-near-cache" type="tns:invalidation-near-cache" minOccurs="0">
<xs:annotation>
<xs:documentation>
Configures using near cache in invalidated mode.
When entries are updated or removed server-side, invalidation messages will be sent to clients to remove them from the near cache.
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="property" type="tns:property" minOccurs="0" maxOccurs="unbounded">
<xs:annotation>
<xs:documentation>
A property with name and value.
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="remote-clusters" type="tns:remote-clusters" minOccurs="0">
<xs:annotation>
<xs:documentation>
Configures remote server clusters for Hot Rod client to connect to.
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="security" type="tns:security" minOccurs="0">
<xs:annotation>
<xs:documentation>
Security configuration.
</xs:documentation>
</xs:annotation>
</xs:element>
<xs:element name="transaction" type="tns:remote-transaction" minOccurs="0">
<xs:annotation>
<xs:documentation>
Transaction configuration.
</xs:documentation>
</xs:annotation>
</xs:element>
</xs:sequence>
<xs:attribute name="connection-timeout" type="xs:int" default="60000">
<xs:annotation>
<xs:documentation>
Defines the maximum socket connect timeout before giving up connecting to the server.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="default-remote-cluster" type="xs:string">
<xs:annotation>
<xs:documentation>
Specifies the default remote server cluster.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="key-size-estimate" type="xs:int" default="64">
<xs:annotation>
<xs:documentation>
This hint allows sizing of byte buffers when serializing and deserializing keys, to minimize array resizing.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="max-retries" type="xs:int" default="10">
<xs:annotation>
<xs:documentation>
Sets the maximum number of retries for each request. A valid value should be greater or equals than 0.
Value of 0 means no retry will made in case of a network failure.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="marshaller" type="tns:marshaller">
<xs:annotation>
<xs:documentation>Defines the marshalling implementation used to marshal cache entries.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="modules" type="tns:list" default="org.jboss.as.clustering.infinispan">
<xs:annotation>
<xs:documentation>Defines the set of modules associated with the configuration of the remote cache container.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="name" type="xs:string" use="required">
<xs:annotation>
<xs:documentation>
Uniquely identifies this remote cache container.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="protocol-version" type="tns:protocol-version" default="3.0">
<xs:annotation>
<xs:documentation>
Defines the protocol version that this client should use.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="socket-timeout" type="xs:long" default="60000">
<xs:annotation>
<xs:documentation>
Enable or disable SO_TIMEOUT on socket connections to remote Hot Rod servers with the specified timeout, in milliseconds.
A timeout of 0 is interpreted as an infinite timeout.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="statistics-enabled" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>
Enables statistics gathering for this remote cache.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="tcp-no-delay" type="xs:boolean" default="true">
<xs:annotation>
<xs:documentation>
Enable or disable TCP_NODELAY on socket connections to remote Hot Rod servers.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="tcp-keep-alive" type="xs:boolean" default="false">
<xs:annotation>
<xs:documentation>
Configures TCP keepalive on the TCP stack.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="transaction-timeout" type="xs:long" default="60000">
<xs:annotation>
<xs:documentation>
The default duration (in ms) after which idle transactions are rolled back.
Only applies to transactional remote caches.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="value-size-estimate" type="xs:int" default="512">
<xs:annotation>
<xs:documentation>
This hint allows sizing of byte buffers when serializing and deserializing values, to minimize array resizing.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="remote-clusters">
<xs:choice>
<xs:element name="remote-cluster" type="tns:remote-cluster" maxOccurs="unbounded">
<xs:annotation>
<xs:documentation>Defines remote server cluster.</xs:documentation>
</xs:annotation>
</xs:element>
</xs:choice>
</xs:complexType>
<xs:complexType name="remote-cluster">
<xs:attribute name="name" type="xs:string">
<xs:annotation>
<xs:documentation>Name of remote server cluster.</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="socket-bindings">
<xs:annotation>
<xs:documentation>List of socket bindings of remote servers.</xs:documentation>
</xs:annotation>
<xs:simpleType>
<xs:list itemType="xs:string"/>
</xs:simpleType>
</xs:attribute>
</xs:complexType>
<xs:complexType name="invalidation-near-cache">
<xs:attribute name="max-entries" type="xs:int">
<xs:annotation>
<xs:documentation>
Defines the maximum number of elements to keep in the near cache.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="connection-pool">
<xs:attribute name="exhausted-action" type="tns:exhausted-action" default="WAIT">
<xs:annotation>
<xs:documentation>
Specifies what happens when asking for a connection from a server's pool, and that pool is exhausted.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="max-active" type="xs:int">
<xs:annotation>
<xs:documentation>
Controls the maximum number of connections per server that are allocated (checked out to client threads, or idle in the pool) at one time.
When undefined, there is no limit to the number of connections per server.
When maxActive is reached, the connection pool for that server is said to be exhausted.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="max-wait" type="xs:int">
<xs:annotation>
<xs:documentation>
The amount of time in milliseconds to wait for a connection to become available when the exhausted action is ExhaustedAction.WAIT,
after which a java.util.NoSuchElementException will be thrown.
If undefined, the pool will block indefinitely.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="min-evictable-idle-time" type="xs:long" default="1800000">
<xs:annotation>
<xs:documentation>
Specifies the minimum amount of time that an connection may sit idle in the pool before it is eligible for eviction due to idle time.
When non-positive, no connection will be dropped from the pool due to idle time alone.
This setting has no effect unless timeBetweenEvictionRunsMillis > 0.
</xs:documentation>
</xs:annotation>
</xs:attribute>
<xs:attribute name="min-idle" type="xs:int" default="1">
<xs:annotation>
<xs:documentation>
Sets a target value for the minimum number of idle connections (per server) that should always be available.
If this parameter is set to a positive number and timeBetweenEvictionRunsMillis > 0, each time the idle connection eviction thread runs,
it will try to create enough idle instances so that there will be minIdle idle instances available for each server.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:simpleType name="exhausted-action">
<xs:restriction base="xs:token">
<xs:enumeration value="EXCEPTION">
<xs:annotation>
<xs:documentation>
An exception will be thrown to the calling user.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="WAIT">
<xs:annotation>
<xs:documentation>
The caller will block by invoking waits until a new or idle connections is available.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="CREATE_NEW">
<xs:annotation>
<xs:documentation>
A new persistent connection will be created and returned thus rendering maxActive meaningless.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="protocol-version">
<xs:restriction base="xs:token">
<xs:enumeration value="2.0"/>
<xs:enumeration value="2.1"/>
<xs:enumeration value="2.2"/>
<xs:enumeration value="2.3"/>
<xs:enumeration value="2.4"/>
<xs:enumeration value="2.5"/>
<xs:enumeration value="2.6"/>
<xs:enumeration value="2.7"/>
<xs:enumeration value="2.8"/>
<xs:enumeration value="2.9"/>
<xs:enumeration value="3.0"/>
</xs:restriction>
</xs:simpleType>
<xs:complexType name="security">
<xs:attribute name="ssl-context" type="xs:string">
<xs:annotation>
<xs:documentation>
Reference to the Elytron-managed SSLContext to be used for connecting to the remote cluster.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:complexType name="remote-transaction">
<xs:attribute name="mode" type="tns:remote-transaction-mode" default="NONE">
<xs:annotation>
<xs:documentation>
Reference to the Elytron-managed SSLContext to be used for connecting to the remote cluster.
</xs:documentation>
</xs:annotation>
</xs:attribute>
</xs:complexType>
<xs:simpleType name="remote-transaction-mode">
<xs:restriction base="tns:transaction-mode">
<xs:enumeration value="NONE">
<xs:annotation>
<xs:documentation>Cache will be non-transactional.</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="BATCH">
<xs:annotation>
<xs:documentation>Cache will support batching of operations.</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="NON_DURABLE_XA">
<xs:annotation>
<xs:documentation>Cache will enlist within transactions as a javax.transaction.xa.XAResource, without recovery.</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
</xs:schema>