Features
Infinispan is designed with ease of use and performance in mind but also gives you enterprise-grade capabilities for a wide range of use cases.
Flexible Deployment Models
- Run as a library inside your applications.
- Deploy as a server with high-performance remote access.
data:image/s3,"s3://crabby-images/a6c0d/a6c0daba32e279814676d178eb41bfa9f3b32ef0" alt=""
data:image/s3,"s3://crabby-images/c2f10/c2f101625c13d534f502c507624d2086f3f768ed" alt=""
Designed for the Cloud
- Lightweight, cloud-native design for microservice architectures.
- Kubernetes Operator that provides operational intelligence.
- Container image that you can run anywhere: OpenShift, AWS EC2, Azure, GCP.
Configurable data storage
- Configure cache modes to distribute and replicate data as needed.
- Encode key/value entries with different storage formats.
- Store data in the JVM heap or native “off-heap” memory.
data:image/s3,"s3://crabby-images/c5add/c5add7f50927bdfab281ed4bc4dd9414cd8ac042" alt=""
data:image/s3,"s3://crabby-images/9c579/9c5799b65d8211bdfeac5fe37e6101a8733a57b1" alt=""
Clusterable and Elastic
- Automatically form clusters with configurable discovery mechanisms.
- Tune consistent hashing to control the nodes where data is located.
- Create global clusters that span multiple data centers.
Secure
- Control access to data based on user roles and permissions.
- Define server security realms that protect you from intrusion and attack.
- Encrypt inter-cluster traffic and remote endpoints.
data:image/s3,"s3://crabby-images/c6fc7/c6fc73e45f9f3eb66629362ad648cee9adece362" alt=""
data:image/s3,"s3://crabby-images/7d2c5/7d2c5012d2dca9a125dd121751eb8e46ded14d53" alt=""
Administration and Monitoring
- Infinispan Console gives you intuitive administration and monitoring capabilities.
- Infinispan CLI provides simple, yet powerful, tooling for administration tasks
- Get statistics and MicroProfile compatible metrics for observability over time.
Developer Tooling
- Quarkus extensions.
- APIs for programmatic usage and extensibility.
- Integration with Hibernate ORM, Spring Boot, JCache, and Wildfly.
data:image/s3,"s3://crabby-images/66675/66675488a3ff1e8a4990100ca198497862633934" alt=""
data:image/s3,"s3://crabby-images/d51fd/d51fd74ffd6dff8beb9dcfc0cab7b6598665636d" alt=""
HotRod Remote Protocol
- Language-independent, binary protocol for high-performance remote access to data.
- Client intelligence dynamically responds to cluster topology changes and requests data from primary owners.
- Implementations available in Java, C++, C#, and Python.
Expiration and Eviction
- Clean the data container and control memory usage.
- Create mortal entries with time limits for remaining in memory.
- Limit size of the data container based on the number of entries or amount of memory.
data:image/s3,"s3://crabby-images/530be/530befd3ad36ca4efe4e56c1127a470328d1f6b4" alt=""
data:image/s3,"s3://crabby-images/8094e/8094e4ef75ba50bb37489b93c88266a2642824ab" alt=""
Persistent Cache Stores
- Store data both in memory and durable persistent locations.
- Cache stores available for File, RocksDB, JDBC, and more out of the box.
- Use write-through caching to eliminate expensive data requests for applications.
ACID Transactions
- Ensure data integrity with distributed transactions.
- Configure transactions with optimistic or pessimistic locking, synchronization, and different isolation levels.
- XA transactions with full recovery available.
data:image/s3,"s3://crabby-images/2577f/2577f45aeeb35e10b1c0d9958a5efebffbf6bb26" alt=""
data:image/s3,"s3://crabby-images/174ab/174ab47fe5fd96d9cadfed9529fd131649f622c5" alt=""
Search
- Ickle query language allows relational and full-text search with straightforward syntax.
- Create indexes of your data to improve search performance.
Event Listeners
- Deploy local or clustered listeners to detect events.
- Get notifications when changes occur to the data store or Infinispan clusters.
data:image/s3,"s3://crabby-images/8dcdd/8dcdd7b2424a4e75a008e18d60d29581f07555a0" alt=""
data:image/s3,"s3://crabby-images/60f8d/60f8dca6cd3aa162ff46554a94c357a42ae569b4" alt=""
Code execution
- Run code across clusters to process data efficiently.
- Create server-side scripts and tasks.