我正在尝试将我的项目代码从 OSCache 迁移到 EhCache。
我们不仅将 OSCache 用作二级 Hibernate 缓存提供程序,而且还用于存储其他不同性质的对象。由于缓存键不重叠,它们都愉快地共享同一个缓存实例,而不会发生任何冲突。
向 EhCache 迁移时的一大区别是每个区域都有不同的缓存实例。这可能很好,因为它可以提高查找速度,因为不同性质的数据是分开存在的。不幸的是,这有配置地狱的代价。让我解释。
在 OSCache 世界中,我会将我的缓存容量配置为 10000。现在,如果特定安装需要/可以提供更多 RAM,我可以轻松地将其增加到 50000,这样就可以了。现在在 EhCache 中,我必须按此增量的一部分为每个区域更改设置!
此外,一个安装可能对 X 类型的对象有更高的使用率,而另一种安装可能更喜欢 Y 类型的对象的更高流失率。我们有几十个安装,每个安装会有数百个不同的缓存。为此,我们将不得不雇佣一群人,除了监控缓存模式和调整设置之外什么都不做!
我期待CacheManager
有某种全局缓存容量设置,每个内部缓存都会争取更多容量,具体取决于条目使用情况。但是,我发现设置缓存容量的唯一方法是通过CacheConfiguration
多对一对抗CacheManager
.
到目前为止,我能看到的唯一选择是尝试强制 Hibernate 为所有实体使用一个全局缓存。有人知道该怎么做吗?对于我的场景,还有其他更好的解决方案吗?