`
penchy
  • 浏览: 57648 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Hibernate缓存(四)

阅读更多

八、二级缓存在项目中的集成和使用

1. echcache.xml 文件拷贝到 src , 二级缓存 hibernate 默认是关闭的,手动开启
2.
开启二级缓存,修改 hibernate .cfg.xml 文件 ,
<property name=”hibernate .cache.user_second_level_cache”>true</property>
3.
指定缓存产品提供商
<property name=”hibernate .cache.provider_calss”>org.hibernate .cache.EhCacheProvider</property>
4.
指定那些实体类使用二级缓存(两种方法,推荐使用第二种)
第一种:在 *.hbm.xml 中,在 <id> 之前加入
<cache usage=”read-only” />,
使用二级缓存
第二种:在 hibernate .cfg.xml 配置文件中 , <mapping resource=”com/Studnet.hbm.xml” /> 后面 加上:
<class-cache class=” com.Studnet” usage=”read-only” />

 

总结:

不要想当然的以为缓存一定能提高性能,仅仅在你能够驾驭它并且条件合适的情况下才是这样的。 hibernate 的二级缓存限制还是比较多的,不方便用 jdbc 可能会大大的降低更新性能。在不了解原理的情况下乱用,可能会有 1+N 的问题。不当的使用还可能导致读出脏数据。

如果受不了 hibernate 的诸多限制,那么还是自己在应用程序的层面上做缓存吧。

在越高的层面上做缓存,效果就会越好 。就好像尽管磁盘有缓存,数据库还是要实现自己的缓存,尽管数据库有缓存,咱们的应用程序还是要做缓存。因为底层的缓存它并不知道高层要用这些数据干什么,只能做的比较通用,而高层可以有针对性的实现缓存,所以在更高的级别上做缓存,效果也要好些吧。

 

对于性能的看法是:合理的性能而不是最高的性能。什么是合理的?用户能感觉到(或敏感的)的范围内,不成为物理上业务处理的瓶颈,比如常说的 3 秒之内响应等。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics