博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
二级缓存在项目中的集成和使用
阅读量:6656 次
发布时间:2019-06-25

本文共 833 字,大约阅读时间需要 2 分钟。

hot3.png

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

1.将echcache.xml文件拷贝到src下, 二级缓存hibernate默认是关闭的,手动开启 

2.开启二级缓存,修改hibernate.cfg.xml文件, 

true

3.指定缓存产品提供商 

org.hibernate.cache.EhCacheProvider

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秒之内响应等。

转载于:https://my.oschina.net/heroShane/blog/204394

你可能感兴趣的文章
Scrapy使用详细记录
查看>>
Python总体架构图
查看>>
Docker 入门学习
查看>>
C/C++ 笔试、面试题目大汇总(转)
查看>>
Tuning 05 Sizing other SGA Structure
查看>>
Ubuntu 16.04 + CUDA 8.0 + cuDNN v5.1 + TensorFlow(GPU support)安装配置详解
查看>>
文件比较软件有哪些
查看>>
Beyond Compare切换到浏览模式的步骤
查看>>
进程、线程与应用程序域
查看>>
HDU 1872:稳定排序
查看>>
MFCchuangkou shanshuo
查看>>
莎莎的简历
查看>>
idea使用maven-archetype-webapp创建多模块项目无java文件夹和resources文件夹
查看>>
ES3之变量提升 ( hoisting )
查看>>
CSS 清除浮动
查看>>
BZOJ 3043
查看>>
JAVA第二次试验
查看>>
IE8下PNG图片格式显示不了问题
查看>>
MVC查询数据接收及校验
查看>>
快速排序(递归与非递归形式)
查看>>