Over a million developers have joined DZone.
{{announcement.body}}
{{announcement.title}}

Ehcache Size Configuration

DZone's Guide to

Ehcache Size Configuration

· Java Zone ·
Free Resource

The CMS developers love. Open Source, API-first and Enterprise-grade. Try BloomReach CMS for free.

Since Ehcache 2.5, you’ve got Automatic Resource Control (ARC), which help you to easily tune your cache.

When you think that software is constantly changing, let’s say you have a class that takes 1Kb when instantiated, then you put 1000000 elements in a cache, it takes 1Gb. After a few releases, the class has been modified, it has more fields, and it takes now 2Kb when instantiated, the exact same cache definition will take 2Gb…

ARC helps you to define a cache by memory size. In this example you say you want your cache to use 1Gb of heap memory, it will first hold 1M elements, then 500000… Your tuning is automatically handled…

In case you want to have a look at ARC vs count-based config, here is a summary of options you can use:

Standalone – Cache Configuration

  Count-based Count-based – legacy pre-2.5 Size-based (ARC)
Heap maxEntriesLocalHeap maxElementsInMemory (deprecated) maxBytesLocalHeap
Off heap maxMemoryOffHeap maxMemoryOffHeap maxBytesLocalOffHeap
Disk maxEntriesLocalDisk maxElementsOnDisk maxBytesLocalDisk

Clustered – Cache Configuration

  Count-based Count-based – legacy pre-2.5 Size-based (ARC)
Heap maxEntriesLocalHeap maxElementsInMemory (deprecated) maxBytesLocalHeap
Off heap maxMemoryOffHeap maxMemoryOffHeap maxBytesLocalOffHeap
Disk NA maxElementsOnDisk NA

more info on Ehcache ARC

BloomReach CMS: the API-first CMS of the future. Open-source & enterprise-grade. - As a Java developer, you will feel at home using Maven builds and your favorite IDE (e.g. Eclipse or IntelliJ) and continuous integration server (e.g. Jenkins). Manage your Java objects using Spring Framework, write your templates in JSP or Freemarker. Try for free.

Topics:

Published at DZone with permission of

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}