jboss-as-infinispan_1_1.xsd 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. ~ JBoss, Home of Professional Open Source.
  4. ~ Copyright 2011, Red Hat, Inc., and individual contributors
  5. ~ as indicated by the @author tags. See the copyright.txt file in the
  6. ~ distribution for a full listing of individual contributors.
  7. ~
  8. ~ This is free software; you can redistribute it and/or modify it
  9. ~ under the terms of the GNU Lesser General Public License as
  10. ~ published by the Free Software Foundation; either version 2.1 of
  11. ~ the License, or (at your option) any later version.
  12. ~
  13. ~ This software is distributed in the hope that it will be useful,
  14. ~ but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. ~ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. ~ Lesser General Public License for more details.
  17. ~
  18. ~ You should have received a copy of the GNU Lesser General Public
  19. ~ License along with this software; if not, write to the Free
  20. ~ Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  21. ~ 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  22. -->
  23. <xs:schema targetNamespace="urn:jboss:domain:infinispan:1.1"
  24. xmlns:xs="http://www.w3.org/2001/XMLSchema"
  25. xmlns:tns="urn:jboss:domain:infinispan:1.1"
  26. elementFormDefault="qualified"
  27. attributeFormDefault="unqualified"
  28. version="1.1">
  29. <xs:element name="subsystem" type="tns:subsystem">
  30. <xs:annotation>
  31. <xs:documentation>Enumerates the cache containers available to the registry.</xs:documentation>
  32. </xs:annotation>
  33. </xs:element>
  34. <xs:complexType name="subsystem">
  35. <xs:choice maxOccurs="unbounded">
  36. <xs:element name="cache-container" type="tns:cache-container">
  37. <xs:annotation>
  38. <xs:documentation>Defines an embedded cache container.</xs:documentation>
  39. </xs:annotation>
  40. </xs:element>
  41. <!-- Preparation for AS7-3156 -->
  42. <!--xs:element name="local-cache-container" type="tns:local-cache-container">
  43. <xs:annotation>
  44. <xs:documentation>Defines an embedded cache container.</xs:documentation>
  45. </xs:annotation>
  46. </xs:element-->
  47. </xs:choice>
  48. <xs:attribute name="default-cache-container" type="xs:string" use="required">
  49. <xs:annotation>
  50. <xs:documentation>Identifies the default cache container.</xs:documentation>
  51. </xs:annotation>
  52. </xs:attribute>
  53. </xs:complexType>
  54. <xs:complexType name="base-cache-container" abstract="true">
  55. <xs:attribute name="name" type="xs:string" use="required">
  56. <xs:annotation>
  57. <xs:documentation>Uniquely identifies this cache container.</xs:documentation>
  58. </xs:annotation>
  59. </xs:attribute>
  60. <xs:attribute name="aliases" type="tns:aliases">
  61. <xs:annotation>
  62. <xs:documentation>A set of aliases by which this cache container may also be referenced.</xs:documentation>
  63. </xs:annotation>
  64. </xs:attribute>
  65. <xs:attribute name="jndi-name" type="xs:string">
  66. <xs:annotation>
  67. <xs:documentation>The jndi name to which to bind this cache container.</xs:documentation>
  68. </xs:annotation>
  69. </xs:attribute>
  70. <xs:attribute name="default-cache" type="xs:string">
  71. <xs:annotation>
  72. <xs:documentation></xs:documentation>
  73. </xs:annotation>
  74. </xs:attribute>
  75. <xs:attribute name="start" type="tns:controller-mode" default="LAZY">
  76. <xs:annotation>
  77. <xs:documentation>Should this cache container be started on server startup, or lazily when requested by a service or deployment.</xs:documentation>
  78. </xs:annotation>
  79. </xs:attribute>
  80. <xs:attribute name="listener-executor" type="xs:string">
  81. <xs:annotation>
  82. <xs:documentation>Defines the executor used for asynchronous cache listener notifications.</xs:documentation>
  83. </xs:annotation>
  84. </xs:attribute>
  85. <xs:attribute name="eviction-executor" type="xs:string">
  86. <xs:annotation>
  87. <xs:documentation>Defines the scheduled executor used for evictions.</xs:documentation>
  88. </xs:annotation>
  89. </xs:attribute>
  90. <xs:attribute name="replication-queue-executor" type="xs:string">
  91. <xs:annotation>
  92. <xs:documentation>Defines the scheduled executor used by the asynchronous replication queue.</xs:documentation>
  93. </xs:annotation>
  94. </xs:attribute>
  95. </xs:complexType>
  96. <!-- Preparation for AS7-3156 -->
  97. <!--xs:complexType name="local-cache-container">
  98. <xs:complexContent>
  99. <xs:extension base="tns:base-cache-container">
  100. <xs:sequence>
  101. <xs:element name="alias" type="xs:string" minOccurs="0" maxOccurs="unbounded">
  102. <xs:annotation>
  103. <xs:documentation>Defines an additional name by which this cache container may be referenced.</xs:documentation>
  104. </xs:annotation>
  105. </xs:element>
  106. <xs:element name="local-cache" type="tns:local-cache" minOccurs="0" maxOccurs="unbounded">
  107. <xs:annotation>
  108. <xs:documentation>Defines a LOCAL mode cache.</xs:documentation>
  109. </xs:annotation>
  110. </xs:element>
  111. </xs:sequence>
  112. </xs:extension>
  113. </xs:complexContent>
  114. </xs:complexType-->
  115. <xs:complexType name="cache-container">
  116. <xs:complexContent>
  117. <xs:extension base="tns:base-cache-container">
  118. <xs:sequence>
  119. <xs:element name="transport" type="tns:transport" minOccurs="0">
  120. <xs:annotation>
  121. <xs:documentation>Overrides the transport characteristics for this cache container.</xs:documentation>
  122. </xs:annotation>
  123. </xs:element>
  124. <xs:choice maxOccurs="unbounded">
  125. <xs:element name="local-cache" type="tns:local-cache">
  126. <xs:annotation>
  127. <xs:documentation>Defines a LOCAL mode cache.</xs:documentation>
  128. </xs:annotation>
  129. </xs:element>
  130. <xs:element name="replicated-cache" type="tns:replicated-cache">
  131. <xs:annotation>
  132. <xs:documentation>Defines a REPL_* mode cache.</xs:documentation>
  133. </xs:annotation>
  134. </xs:element>
  135. <xs:element name="invalidation-cache" type="tns:invalidation-cache">
  136. <xs:annotation>
  137. <xs:documentation>Defines an INVALIDATION_* mode cache.</xs:documentation>
  138. </xs:annotation>
  139. </xs:element>
  140. <xs:element name="distributed-cache" type="tns:distributed-cache">
  141. <xs:annotation>
  142. <xs:documentation>Defines a DIST_* mode cache.</xs:documentation>
  143. </xs:annotation>
  144. </xs:element>
  145. </xs:choice>
  146. </xs:sequence>
  147. </xs:extension>
  148. </xs:complexContent>
  149. </xs:complexType>
  150. <xs:complexType name="transport">
  151. <xs:attribute name="stack" type="xs:string">
  152. <xs:annotation>
  153. <xs:documentation>Defines the jgroups stack used by the transport.</xs:documentation>
  154. </xs:annotation>
  155. </xs:attribute>
  156. <xs:attribute name="executor" type="xs:string" >
  157. <xs:annotation>
  158. <xs:documentation>Defines the executor used for asynchronous transport communication.</xs:documentation>
  159. </xs:annotation>
  160. </xs:attribute>
  161. <xs:attribute name="lock-timeout" type="xs:long" default="240000">
  162. <xs:annotation>
  163. <xs:documentation>
  164. 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.
  165. This constraint is in place because more than one cache could be involved in a transaction.
  166. This timeout controls the time to wait to acquire acquire a lock on the distributed lock.
  167. </xs:documentation>
  168. </xs:annotation>
  169. </xs:attribute>
  170. </xs:complexType>
  171. <xs:complexType name="cache" abstract="true">
  172. <xs:sequence>
  173. <xs:element name="locking" type="tns:locking" minOccurs="0">
  174. <xs:annotation>
  175. <xs:documentation></xs:documentation>
  176. </xs:annotation>
  177. </xs:element>
  178. <xs:element name="transaction" type="tns:transaction" minOccurs="0">
  179. <xs:annotation>
  180. <xs:documentation></xs:documentation>
  181. </xs:annotation>
  182. </xs:element>
  183. <xs:element name="eviction" type="tns:eviction" minOccurs="0">
  184. <xs:annotation>
  185. <xs:documentation></xs:documentation>
  186. </xs:annotation>
  187. </xs:element>
  188. <xs:element name="expiration" type="tns:expiration" minOccurs="0">
  189. <xs:annotation>
  190. <xs:documentation></xs:documentation>
  191. </xs:annotation>
  192. </xs:element>
  193. <xs:choice minOccurs="0">
  194. <xs:element name="store" type="tns:custom-store">
  195. <xs:annotation>
  196. <xs:documentation>Defines a custom cache store.</xs:documentation>
  197. </xs:annotation>
  198. </xs:element>
  199. <xs:element name="file-store" type="tns:file-store">
  200. <xs:annotation>
  201. <xs:documentation>Defines a file-based cache store.</xs:documentation>
  202. </xs:annotation>
  203. </xs:element>
  204. <xs:element name="jdbc-store" type="tns:jdbc-store">
  205. <xs:annotation>
  206. <xs:documentation>Defines a database cache store accessed via JDBC.</xs:documentation>
  207. </xs:annotation>
  208. </xs:element>
  209. <xs:element name="remote-store" type="tns:remote-store">
  210. <xs:annotation>
  211. <xs:documentation>
  212. Defines a remote cache store accessed via HotRod.
  213. Nested properties will be treated as HotRod client properties.
  214. </xs:documentation>
  215. </xs:annotation>
  216. </xs:element>
  217. </xs:choice>
  218. </xs:sequence>
  219. <xs:attribute name="name" type="xs:string" use="required">
  220. <xs:annotation>
  221. <xs:documentation>Uniquely identifies this cache within its cache container.</xs:documentation>
  222. </xs:annotation>
  223. </xs:attribute>
  224. <xs:attribute name="start" type="tns:controller-mode" default="LAZY">
  225. <xs:annotation>
  226. <xs:documentation>Should this cache be started on server startup, or lazily when requested by a service or deployment.</xs:documentation>
  227. </xs:annotation>
  228. </xs:attribute>
  229. <xs:attribute name="batching" type="xs:boolean" default="false">
  230. <xs:annotation>
  231. <xs:documentation></xs:documentation>
  232. </xs:annotation>
  233. </xs:attribute>
  234. <xs:attribute name="indexing" type="tns:indexing" default="NONE">
  235. <xs:annotation>
  236. <xs:documentation></xs:documentation>
  237. </xs:annotation>
  238. </xs:attribute>
  239. <xs:attribute name="jndi-name" type="xs:string">
  240. <xs:annotation>
  241. <xs:documentation>The jndi name to which to bind this cache.</xs:documentation>
  242. </xs:annotation>
  243. </xs:attribute>
  244. </xs:complexType>
  245. <xs:complexType name="local-cache">
  246. <xs:complexContent>
  247. <xs:extension base="tns:cache"></xs:extension>
  248. </xs:complexContent>
  249. </xs:complexType>
  250. <xs:complexType name="locking">
  251. <xs:attribute name="isolation" type="tns:isolation" default="REPEATABLE_READ">
  252. <xs:annotation>
  253. <xs:documentation></xs:documentation>
  254. </xs:annotation>
  255. </xs:attribute>
  256. <xs:attribute name="striping" type="xs:boolean" default="false">
  257. <xs:annotation>
  258. <xs:documentation></xs:documentation>
  259. </xs:annotation>
  260. </xs:attribute>
  261. <xs:attribute name="acquire-timeout" type="xs:long" default="15000">
  262. <xs:annotation>
  263. <xs:documentation></xs:documentation>
  264. </xs:annotation>
  265. </xs:attribute>
  266. <xs:attribute name="concurrency-level" type="xs:int" default="1000">
  267. <xs:annotation>
  268. <xs:documentation></xs:documentation>
  269. </xs:annotation>
  270. </xs:attribute>
  271. </xs:complexType>
  272. <xs:complexType name="transaction">
  273. <xs:attribute name="mode" type="tns:transaction-mode" default="NONE">
  274. <xs:annotation>
  275. <xs:documentation></xs:documentation>
  276. </xs:annotation>
  277. </xs:attribute>
  278. <xs:attribute name="stop-timeout" type="xs:long" default="30000">
  279. <xs:annotation>
  280. <xs:documentation></xs:documentation>
  281. </xs:annotation>
  282. </xs:attribute>
  283. <xs:attribute name="locking" type="tns:locking-mode" default="OPTIMISTIC">
  284. <xs:annotation>
  285. <xs:documentation></xs:documentation>
  286. </xs:annotation>
  287. </xs:attribute>
  288. </xs:complexType>
  289. <xs:complexType name="eviction">
  290. <xs:attribute name="strategy" type="tns:eviction-strategy" default="NONE">
  291. <xs:annotation>
  292. <xs:documentation></xs:documentation>
  293. </xs:annotation>
  294. </xs:attribute>
  295. <xs:attribute name="max-entries" type="xs:int" default="10000">
  296. <xs:annotation>
  297. <xs:documentation></xs:documentation>
  298. </xs:annotation>
  299. </xs:attribute>
  300. </xs:complexType>
  301. <xs:complexType name="expiration">
  302. <xs:attribute name="max-idle" type="xs:long" default="-1">
  303. <xs:annotation>
  304. <xs:documentation></xs:documentation>
  305. </xs:annotation>
  306. </xs:attribute>
  307. <xs:attribute name="lifespan" type="xs:long" default="-1">
  308. <xs:annotation>
  309. <xs:documentation></xs:documentation>
  310. </xs:annotation>
  311. </xs:attribute>
  312. <xs:attribute name="interval" type="xs:long" default="5000">
  313. <xs:annotation>
  314. <xs:documentation></xs:documentation>
  315. </xs:annotation>
  316. </xs:attribute>
  317. </xs:complexType>
  318. <xs:complexType name="clustered-cache" abstract="true">
  319. <xs:complexContent>
  320. <xs:extension base="tns:cache">
  321. <xs:attribute name="mode" type="tns:mode" use="required">
  322. <xs:annotation>
  323. <xs:documentation></xs:documentation>
  324. </xs:annotation>
  325. </xs:attribute>
  326. <xs:attribute name="queue-size" type="xs:int" default="0">
  327. <xs:annotation>
  328. <xs:documentation></xs:documentation>
  329. </xs:annotation>
  330. </xs:attribute>
  331. <xs:attribute name="queue-flush-interval" type="xs:long" default="10">
  332. <xs:annotation>
  333. <xs:documentation></xs:documentation>
  334. </xs:annotation>
  335. </xs:attribute>
  336. <xs:attribute name="remote-timeout" type="xs:long" default="17500">
  337. <xs:annotation>
  338. <xs:documentation></xs:documentation>
  339. </xs:annotation>
  340. </xs:attribute>
  341. </xs:extension>
  342. </xs:complexContent>
  343. </xs:complexType>
  344. <xs:complexType name="invalidation-cache">
  345. <xs:complexContent>
  346. <xs:extension base="tns:clustered-cache">
  347. </xs:extension>
  348. </xs:complexContent>
  349. </xs:complexType>
  350. <xs:complexType name="replicated-cache">
  351. <xs:complexContent>
  352. <xs:extension base="tns:clustered-cache">
  353. <xs:sequence>
  354. <xs:element name="state-transfer" type="tns:state-transfer" minOccurs="0">
  355. <xs:annotation>
  356. <xs:documentation></xs:documentation>
  357. </xs:annotation>
  358. </xs:element>
  359. </xs:sequence>
  360. </xs:extension>
  361. </xs:complexContent>
  362. </xs:complexType>
  363. <xs:complexType name="distributed-cache">
  364. <xs:complexContent>
  365. <xs:extension base="tns:clustered-cache">
  366. <xs:sequence>
  367. <xs:element name="state-transfer" type="tns:state-transfer" minOccurs="0">
  368. <xs:annotation>
  369. <xs:documentation></xs:documentation>
  370. </xs:annotation>
  371. </xs:element>
  372. </xs:sequence>
  373. <xs:attribute name="owners" type="xs:int" default="2">
  374. <xs:annotation>
  375. <xs:documentation>Number of cluster-wide replicas for each cache entry.</xs:documentation>
  376. </xs:annotation>
  377. </xs:attribute>
  378. <xs:attribute name="virtual-nodes" type="xs:int" default="1">
  379. <xs:annotation>
  380. <xs:documentation>Controls the number of virtual nodes per "real" node.</xs:documentation>
  381. </xs:annotation>
  382. </xs:attribute>
  383. <xs:attribute name="l1-lifespan" type="xs:long" default="600000">
  384. <xs:annotation>
  385. <xs:documentation></xs:documentation>
  386. </xs:annotation>
  387. </xs:attribute>
  388. </xs:extension>
  389. </xs:complexContent>
  390. </xs:complexType>
  391. <xs:complexType name="store" abstract="true">
  392. <xs:sequence>
  393. <xs:element name="property" type="tns:property" minOccurs="0" maxOccurs="unbounded">
  394. <xs:annotation>
  395. <xs:documentation></xs:documentation>
  396. </xs:annotation>
  397. </xs:element>
  398. </xs:sequence>
  399. <xs:attribute name="shared" type="xs:boolean" default="false">
  400. <xs:annotation>
  401. <xs:documentation></xs:documentation>
  402. </xs:annotation>
  403. </xs:attribute>
  404. <xs:attribute name="preload" type="xs:boolean" default="false">
  405. <xs:annotation>
  406. <xs:documentation></xs:documentation>
  407. </xs:annotation>
  408. </xs:attribute>
  409. <xs:attribute name="passivation" type="xs:boolean" default="true">
  410. <xs:annotation>
  411. <xs:documentation></xs:documentation>
  412. </xs:annotation>
  413. </xs:attribute>
  414. <xs:attribute name="fetch-state" type="xs:boolean" default="true">
  415. <xs:annotation>
  416. <xs:documentation></xs:documentation>
  417. </xs:annotation>
  418. </xs:attribute>
  419. <xs:attribute name="purge" type="xs:boolean" default="true">
  420. <xs:annotation>
  421. <xs:documentation></xs:documentation>
  422. </xs:annotation>
  423. </xs:attribute>
  424. <xs:attribute name="singleton" type="xs:boolean" default="false">
  425. <xs:annotation>
  426. <xs:documentation></xs:documentation>
  427. </xs:annotation>
  428. </xs:attribute>
  429. </xs:complexType>
  430. <xs:complexType name="custom-store">
  431. <xs:complexContent>
  432. <xs:extension base="tns:store">
  433. <xs:attribute name="class" type="xs:string" use="required">
  434. <xs:annotation>
  435. <xs:documentation>The class name of the cache store implementation.</xs:documentation>
  436. </xs:annotation>
  437. </xs:attribute>
  438. </xs:extension>
  439. </xs:complexContent>
  440. </xs:complexType>
  441. <xs:complexType name="file-store">
  442. <xs:complexContent>
  443. <xs:extension base="tns:store">
  444. <xs:attribute name="relative-to" type="xs:string" default="jboss.server.data.dir">
  445. <xs:annotation>
  446. <xs:documentation>The base directory in which to store the cache state.</xs:documentation>
  447. </xs:annotation>
  448. </xs:attribute>
  449. <xs:attribute name="path" type="xs:string">
  450. <xs:annotation>
  451. <xs:documentation>
  452. The path within "relative-to" in which to store the cache state.
  453. If undefined, the path defaults to the cache container name.
  454. </xs:documentation>
  455. </xs:annotation>
  456. </xs:attribute>
  457. </xs:extension>
  458. </xs:complexContent>
  459. </xs:complexType>
  460. <xs:complexType name="remote-store">
  461. <xs:complexContent>
  462. <xs:extension base="tns:store">
  463. <xs:sequence>
  464. <xs:element name="remote-server" type="tns:remote-server" minOccurs="1" maxOccurs="unbounded"/>
  465. </xs:sequence>
  466. <xs:attribute name="cache" type="xs:string">
  467. <xs:annotation>
  468. <xs:documentation>The name of the remote cache. If undefined, the default cache will be used.</xs:documentation>
  469. </xs:annotation>
  470. </xs:attribute>
  471. <xs:attribute name="socket-timeout" type="xs:long" default="60000">
  472. <xs:annotation>
  473. <xs:documentation>
  474. Enable/disable SO_TIMEOUT on socket connections to remote Hot Rod servers with the specified timeout, in milliseconds.
  475. A timeout of zero is interpreted as an infinite timeout.
  476. </xs:documentation>
  477. </xs:annotation>
  478. </xs:attribute>
  479. <xs:attribute name="tcp-no-delay" type="xs:boolean" default="true">
  480. <xs:annotation>
  481. <xs:documentation>
  482. Enable/disable TCP_NODELAY on socket connections to remote Hot Rod servers.
  483. </xs:documentation>
  484. </xs:annotation>
  485. </xs:attribute>
  486. </xs:extension>
  487. </xs:complexContent>
  488. </xs:complexType>
  489. <xs:complexType name="remote-server">
  490. <xs:attribute name="outbound-socket-binding" type="xs:string" use="required">
  491. <xs:annotation>
  492. <xs:documentation></xs:documentation>
  493. </xs:annotation>
  494. </xs:attribute>
  495. </xs:complexType>
  496. <xs:complexType name="jdbc-store">
  497. <xs:complexContent>
  498. <xs:extension base="tns:store">
  499. <xs:sequence>
  500. <xs:element name="bucket-table" type="tns:bucket-table" minOccurs="0">
  501. <xs:annotation>
  502. <xs:documentation>
  503. Defines the table used to store cache buckets.
  504. If an entry-table is also defined, a mixed-mode cache store will be used.
  505. </xs:documentation>
  506. </xs:annotation>
  507. </xs:element>
  508. <xs:element name="entry-table" type="tns:entry-table" minOccurs="0">
  509. <xs:annotation>
  510. <xs:documentation>
  511. Defines the table used to store cache entries.
  512. If a bucket-table is also defined, a mixed-mode cache store will be used.
  513. </xs:documentation>
  514. </xs:annotation>
  515. </xs:element>
  516. </xs:sequence>
  517. <xs:attribute name="datasource" type="xs:string" use="required">
  518. <xs:annotation>
  519. <xs:documentation>Defines the jndi name of the datasource.</xs:documentation>
  520. </xs:annotation>
  521. </xs:attribute>
  522. </xs:extension>
  523. </xs:complexContent>
  524. </xs:complexType>
  525. <xs:complexType name="entry-table">
  526. <xs:complexContent>
  527. <xs:extension base="tns:table">
  528. <xs:attribute name="prefix" type="xs:string" default="ispn_entry">
  529. <xs:annotation>
  530. <xs:documentation>Defines the prefix prepended to the cache name used when composing the name of the cache entry table.</xs:documentation>
  531. </xs:annotation>
  532. </xs:attribute>
  533. </xs:extension>
  534. </xs:complexContent>
  535. </xs:complexType>
  536. <xs:complexType name="bucket-table">
  537. <xs:complexContent>
  538. <xs:extension base="tns:table">
  539. <xs:attribute name="prefix" type="xs:string" default="ispn_bucket">
  540. <xs:annotation>
  541. <xs:documentation>Defines the prefix prepended to the cache name used when composing the name of the cache bucket table.</xs:documentation>
  542. </xs:annotation>
  543. </xs:attribute>
  544. </xs:extension>
  545. </xs:complexContent>
  546. </xs:complexType>
  547. <xs:complexType name="table">
  548. <xs:sequence>
  549. <xs:element name="id-column" type="tns:id-column" minOccurs="0">
  550. <xs:annotation>
  551. <xs:documentation>Defines the column in which to store the cache key or bucket id.</xs:documentation>
  552. </xs:annotation>
  553. </xs:element>
  554. <xs:element name="data-column" type="tns:data-column" minOccurs="0">
  555. <xs:annotation>
  556. <xs:documentation>Defines the column in which to store the cache entry or bucket.</xs:documentation>
  557. </xs:annotation>
  558. </xs:element>
  559. <xs:element name="timestamp-column" type="tns:timestamp-column" minOccurs="0">
  560. <xs:annotation>
  561. <xs:documentation>Defines the column in which to store the timestamp of the cache entry or bucket.</xs:documentation>
  562. </xs:annotation>
  563. </xs:element>
  564. </xs:sequence>
  565. <xs:attribute name="fetch-size" type="xs:int" default="100">
  566. <xs:annotation>
  567. <xs:documentation>The fetch size used when querying from this table. Used to avoid heap memory exhaustion when query is large.</xs:documentation>
  568. </xs:annotation>
  569. </xs:attribute>
  570. <xs:attribute name="batch-size" type="xs:int" default="100">
  571. <xs:annotation>
  572. <xs:documentation>The statement batch size used when modifying this table.</xs:documentation>
  573. </xs:annotation>
  574. </xs:attribute>
  575. </xs:complexType>
  576. <xs:complexType name="id-column">
  577. <xs:attribute name="name" type="xs:string" default="id">
  578. <xs:annotation>
  579. <xs:documentation>The name of the column used to store the cache key or bucket id.</xs:documentation>
  580. </xs:annotation>
  581. </xs:attribute>
  582. <xs:attribute name="type" type="xs:string" default="VARCHAR">
  583. <xs:annotation>
  584. <xs:documentation>The type of the column used to store the cache key or bucket id.</xs:documentation>
  585. </xs:annotation>
  586. </xs:attribute>
  587. </xs:complexType>
  588. <xs:complexType name="data-column">
  589. <xs:attribute name="name" type="xs:string" default="datum">
  590. <xs:annotation>
  591. <xs:documentation>The name of the column used to store the cache entry or bucket.</xs:documentation>
  592. </xs:annotation>
  593. </xs:attribute>
  594. <xs:attribute name="type" type="xs:string" default="BINARY">
  595. <xs:annotation>
  596. <xs:documentation>The type of the column used to store the cache entry or bucket.</xs:documentation>
  597. </xs:annotation>
  598. </xs:attribute>
  599. </xs:complexType>
  600. <xs:complexType name="timestamp-column">
  601. <xs:attribute name="name" type="xs:string" default="version">
  602. <xs:annotation>
  603. <xs:documentation>The name of the column used to store the cache entry or bucket timestamp.</xs:documentation>
  604. </xs:annotation>
  605. </xs:attribute>
  606. <xs:attribute name="type" type="xs:string" default="BIGINT">
  607. <xs:annotation>
  608. <xs:documentation>The type of the column used to store the cache entry or bucket timestamp.</xs:documentation>
  609. </xs:annotation>
  610. </xs:attribute>
  611. </xs:complexType>
  612. <xs:complexType name="state-transfer">
  613. <xs:attribute name="enabled" type="xs:boolean" default="true">
  614. <xs:annotation>
  615. <xs:documentation></xs:documentation>
  616. </xs:annotation>
  617. </xs:attribute>
  618. <xs:attribute name="timeout" type="xs:long" default="60000">
  619. <xs:annotation>
  620. <xs:documentation></xs:documentation>
  621. </xs:annotation>
  622. </xs:attribute>
  623. <xs:attribute name="chunk-size" type="xs:integer" default="10000">
  624. <xs:annotation>
  625. <xs:documentation></xs:documentation>
  626. </xs:annotation>
  627. </xs:attribute>
  628. </xs:complexType>
  629. <xs:complexType name="property">
  630. <xs:simpleContent>
  631. <xs:extension base="xs:string">
  632. <xs:attribute name="name" type="xs:string" use="required">
  633. <xs:annotation>
  634. <xs:documentation>Defines the name of a property.</xs:documentation>
  635. </xs:annotation>
  636. </xs:attribute>
  637. </xs:extension>
  638. </xs:simpleContent>
  639. </xs:complexType>
  640. <xs:simpleType name="isolation">
  641. <xs:restriction base="xs:token">
  642. <xs:enumeration value="NONE">
  643. <xs:annotation>
  644. <xs:documentation></xs:documentation>
  645. </xs:annotation>
  646. </xs:enumeration>
  647. <xs:enumeration value="READ_UNCOMMITTED">
  648. <xs:annotation>
  649. <xs:documentation></xs:documentation>
  650. </xs:annotation>
  651. </xs:enumeration>
  652. <xs:enumeration value="READ_COMMITTED">
  653. <xs:annotation>
  654. <xs:documentation></xs:documentation>
  655. </xs:annotation>
  656. </xs:enumeration>
  657. <xs:enumeration value="REPEATABLE_READ">
  658. <xs:annotation>
  659. <xs:documentation></xs:documentation>
  660. </xs:annotation>
  661. </xs:enumeration>
  662. <xs:enumeration value="SERIALIZABLE">
  663. <xs:annotation>
  664. <xs:documentation></xs:documentation>
  665. </xs:annotation>
  666. </xs:enumeration>
  667. </xs:restriction>
  668. </xs:simpleType>
  669. <xs:simpleType name="transaction-mode">
  670. <xs:restriction base="xs:token">
  671. <xs:enumeration value="NONE">
  672. <xs:annotation>
  673. <xs:documentation>Cache will not enlist within transactions.</xs:documentation>
  674. </xs:annotation>
  675. </xs:enumeration>
  676. <xs:enumeration value="NON_XA">
  677. <xs:annotation>
  678. <xs:documentation>Cache will enlist within transactions as a javax.transaction.Synchronization</xs:documentation>
  679. </xs:annotation>
  680. </xs:enumeration>
  681. <xs:enumeration value="NON_DURABLE_XA">
  682. <xs:annotation>
  683. <xs:documentation>Cache will enlist within transactions as a javax.transaction.xa.XAResource, without recovery.</xs:documentation>
  684. </xs:annotation>
  685. </xs:enumeration>
  686. <xs:enumeration value="FULL_XA">
  687. <xs:annotation>
  688. <xs:documentation>Cache will enlist within transactions as a javax.transaction.xa.XAResource, with recovery.</xs:documentation>
  689. </xs:annotation>
  690. </xs:enumeration>
  691. </xs:restriction>
  692. </xs:simpleType>
  693. <xs:simpleType name="eager-locking">
  694. <xs:restriction base="xs:token">
  695. <xs:enumeration value="NONE">
  696. <xs:annotation>
  697. <xs:documentation></xs:documentation>
  698. </xs:annotation>
  699. </xs:enumeration>
  700. <xs:enumeration value="SINGLE">
  701. <xs:annotation>
  702. <xs:documentation></xs:documentation>
  703. </xs:annotation>
  704. </xs:enumeration>
  705. <xs:enumeration value="ALL">
  706. <xs:annotation>
  707. <xs:documentation></xs:documentation>
  708. </xs:annotation>
  709. </xs:enumeration>
  710. </xs:restriction>
  711. </xs:simpleType>
  712. <xs:simpleType name="indexing">
  713. <xs:restriction base="xs:token">
  714. <xs:enumeration value="NONE">
  715. <xs:annotation>
  716. <xs:documentation></xs:documentation>
  717. </xs:annotation>
  718. </xs:enumeration>
  719. <xs:enumeration value="LOCAL">
  720. <xs:annotation>
  721. <xs:documentation></xs:documentation>
  722. </xs:annotation>
  723. </xs:enumeration>
  724. <xs:enumeration value="ALL">
  725. <xs:annotation>
  726. <xs:documentation></xs:documentation>
  727. </xs:annotation>
  728. </xs:enumeration>
  729. </xs:restriction>
  730. </xs:simpleType>
  731. <xs:simpleType name="eviction-strategy">
  732. <xs:restriction base="xs:token">
  733. <xs:enumeration value="NONE">
  734. <xs:annotation>
  735. <xs:documentation></xs:documentation>
  736. </xs:annotation>
  737. </xs:enumeration>
  738. <xs:enumeration value="UNORDERED">
  739. <xs:annotation>
  740. <xs:documentation></xs:documentation>
  741. </xs:annotation>
  742. </xs:enumeration>
  743. <xs:enumeration value="FIFO">
  744. <xs:annotation>
  745. <xs:documentation></xs:documentation>
  746. </xs:annotation>
  747. </xs:enumeration>
  748. <xs:enumeration value="LRU">
  749. <xs:annotation>
  750. <xs:documentation></xs:documentation>
  751. </xs:annotation>
  752. </xs:enumeration>
  753. <xs:enumeration value="LIRS">
  754. <xs:annotation>
  755. <xs:documentation></xs:documentation>
  756. </xs:annotation>
  757. </xs:enumeration>
  758. </xs:restriction>
  759. </xs:simpleType>
  760. <xs:simpleType name="mode">
  761. <xs:restriction base="xs:token">
  762. <xs:enumeration value="ASYNC">
  763. <xs:annotation>
  764. <xs:documentation></xs:documentation>
  765. </xs:annotation>
  766. </xs:enumeration>
  767. <xs:enumeration value="SYNC">
  768. <xs:annotation>
  769. <xs:documentation></xs:documentation>
  770. </xs:annotation>
  771. </xs:enumeration>
  772. </xs:restriction>
  773. </xs:simpleType>
  774. <xs:simpleType name="locking-mode">
  775. <xs:restriction base="xs:token">
  776. <xs:enumeration value="OPTIMISTIC">
  777. <xs:annotation>
  778. <xs:documentation></xs:documentation>
  779. </xs:annotation>
  780. </xs:enumeration>
  781. <xs:enumeration value="PESSIMISTIC">
  782. <xs:annotation>
  783. <xs:documentation></xs:documentation>
  784. </xs:annotation>
  785. </xs:enumeration>
  786. </xs:restriction>
  787. </xs:simpleType>
  788. <xs:simpleType name="controller-mode">
  789. <xs:restriction base="xs:token">
  790. <xs:enumeration value="EAGER">
  791. <xs:annotation>
  792. <xs:documentation></xs:documentation>
  793. </xs:annotation>
  794. </xs:enumeration>
  795. <xs:enumeration value="LAZY">
  796. <xs:annotation>
  797. <xs:documentation></xs:documentation>
  798. </xs:annotation>
  799. </xs:enumeration>
  800. </xs:restriction>
  801. </xs:simpleType>
  802. <xs:simpleType name="aliases">
  803. <xs:annotation>
  804. <xs:documentation>A list of aliases.</xs:documentation>
  805. </xs:annotation>
  806. <xs:list itemType="xs:string"/>
  807. </xs:simpleType>
  808. </xs:schema>