【找集中式缓存做hibernate second level cache和业务缓存失败】
2013-07-28 14:50
369 查看
首先是需求:
1.Hibernate的二级缓存
2.独立的业务缓存
3.支持region,支持keySet,containsKey,region内遍历
首先看了大名鼎鼎的memcached,以及客户端spymemcached.失败。首先,不支持region,各种轮子都是在key上加前缀之类的做文章。不支持keySet,不支持containsKey,不支持遍历。于是Pass.
然后看到了ehcache server,可惜人家似乎发展商业版本的torrxxxx去了,ehcache server也2年多没有更新,并且没有hibernate二级缓存结合的任何文档、网文。Pass.
然后看到了Infinispan,据说是jboss cache 的后继。也看到了hibernate-infinispan,也支持分区,心里一阵高兴。使用RemoteCacheStore可以实现hibernate的二级缓存以及查询缓存使用远端的缓存服务器。深入尝试,结果发现,首先,一定要jta,太不平民化了。其次,hibernate-infinispan里面明确写了只支持read-only,non-restrict-read-write,transactional这三种缓存策略。但是我的已有代码中有很多事read-write的。于是失败了。
最后看到了redis,以及jedis.当前火爆的nosql数据库。想来也可以实现我要的功能。根据网文,可以使用hashes的方式实现region.这个方面基本上符合要求。然后很高兴在github上也找到了hibernate-redis这个项目,仔细一看,只支持ghost xp系统下载之家read-only,non-restrict-read-write这两种缓存策略。郁闷死了。后来同样在github上看到一个jedis-lock项目,做了redis的锁机制。开始尝试修改hibernate-redis,依赖jedis-lock,想做个read-write策略出来,结果发现自己对hibernate的cache部分还是不太熟悉,里面各种softLock之类的东西,看ehcache的代码就看头大了。
1.Hibernate的二级缓存
2.独立的业务缓存
3.支持region,支持keySet,containsKey,region内遍历
首先看了大名鼎鼎的memcached,以及客户端spymemcached.失败。首先,不支持region,各种轮子都是在key上加前缀之类的做文章。不支持keySet,不支持containsKey,不支持遍历。于是Pass.
然后看到了ehcache server,可惜人家似乎发展商业版本的torrxxxx去了,ehcache server也2年多没有更新,并且没有hibernate二级缓存结合的任何文档、网文。Pass.
然后看到了Infinispan,据说是jboss cache 的后继。也看到了hibernate-infinispan,也支持分区,心里一阵高兴。使用RemoteCacheStore可以实现hibernate的二级缓存以及查询缓存使用远端的缓存服务器。深入尝试,结果发现,首先,一定要jta,太不平民化了。其次,hibernate-infinispan里面明确写了只支持read-only,non-restrict-read-write,transactional这三种缓存策略。但是我的已有代码中有很多事read-write的。于是失败了。
最后看到了redis,以及jedis.当前火爆的nosql数据库。想来也可以实现我要的功能。根据网文,可以使用hashes的方式实现region.这个方面基本上符合要求。然后很高兴在github上也找到了hibernate-redis这个项目,仔细一看,只支持ghost xp系统下载之家read-only,non-restrict-read-write这两种缓存策略。郁闷死了。后来同样在github上看到一个jedis-lock项目,做了redis的锁机制。开始尝试修改hibernate-redis,依赖jedis-lock,想做个read-write策略出来,结果发现自己对hibernate的cache部分还是不太熟悉,里面各种softLock之类的东西,看ehcache的代码就看头大了。
相关文章推荐
- 异常:org.hibernate.cache.NoCachingEnabledException: Second-level cache is not enabled for usage [hiber
- org.hibernate.cache.NoCachingEnabledException: Second-level cache is not enabled for usage
- hibernate_二级缓存(second cache)
- Understanding Caching in Hibernate – Part Three : The Second Level Cache
- org.hibernate.cache.NoCachingEnabledException: Second-level cache is not enabled for usage
- org.hibernate.cache.NoCachingEnabledException: Second-level cache is not enabled for usage
- org.hibernate.cache.NoCachingEnabledException: Second-level cache is not enabled
- Hibernate EHCache Second Level Cache Example
- EF 二级缓存 EFSecondLevelCache
- Hibernate 4 Second Level Caching With EHCache
- 缓存简介--Cache In Hibernate: @Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
- The Second Level Cache
- Hazelcast作为hibernate缓存和业务缓存
- hibernate中cache二级缓存问题
- Second Level Cache for Entity Framework 6.1
- Hibernate缓存之Aop+cache
- Hibernate 一级缓存(First-level cache)和二级缓存(second-level cache) 介绍
- Understanding hibernate first level cache with example
- Hadoop浅解Centralized Cache Management(集中式缓存管理)
- 推荐 IIS7.0下ThinkPHP提示“缓存文件写入失败!” 需要设置user的权限即可 Home/Runtime/Cache/