Java的应用缓存cache如何入门?

我这里说的cache不是指CPU和RAM之间的缓存,而是java应用中间常用的缓存。它是否跟Hibernate的Session是一样的概念呢? 请大神们指教下

跟session不是一个概念,简单的谈下我个人对缓存的看法吧,你可以把它想象成一个容量大的hashMap,可以往里面get set数据,由于数据存在内存当中而不是数据库中,所以存取速度较快。

java常用的缓存有:ehcache, oscache,jcache,这些cache都是单机的,即存在本机的内存中,另外分布式的cache我用过memcache,它被独立部署在一台服务器上,可以实现多个客户端共用缓存。

一般用到缓存的场景:1.在处理并发请求,需要及时响应的。2.加快系统响应速度。举个例子:比如购物网站有 售卖物品的排行榜,这种数据都是由数据库中N多表关联查询排序得到的,那么就可以存在缓存当中,当页面请求查看排行榜时直接取缓存中的数据。后台定时任务根据一定的时间间隔计算好排行结果,再替换到当前缓存中。 这就是一个简单的缓存应用示例。

具体用法你可以参考 各个缓存的说明文档,百度一下很多的。 纯手打,望采纳~追问

大哥 你真厉害! 谢谢分享

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2018-03-29

Java的应用缓存cache入门:

    java常用的缓存有:ehcache, oscache,jcache,这些cache都是单机的,即存在本机的内存中,另外分布式的cache我用过memcache,它被独立部署在一台服务器上,可以实现多个客户端共用缓存;

    一般用到缓存的场景:

1.在处理并发请求,需要及时响应的。

2.加快系统响应速度。举个例子:比如购物网站有  售卖物品的排行榜,这种数据都是由数据库中N多表关联查询排序得到的,那么就可以存在缓存当中,当页面请求查看排行榜时直接取缓存中的数据。后台定时任务根据一定的时间间隔计算好排行结果,再替换到当前缓存中。

  这就是一个简单的缓存应用示例。

第2个回答  2014-09-23
你可以先看看java中的java.util.Properties;缓存可以理解为一个单例的对象或资源,经常性占用一块内存。
Session:在计算机中,尤其是在网络应用中,称为“会话”。Session直接翻译成中文比较困难,一般都译成时域。在计算机专业术语中,Session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册进入系统到注销退出系统之间所经过的时间。具体到Web中的Session指的就是用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间。因此从上述的定义中我们可以看到,Session实际上是一个特定的时间概念。
Hibernate中的session作用类似。hibernate有二级缓存机制,类似数据库中sql池的概念,它会缓存经常执行的HQL以及其对应的执行结果,以减少IO操作。追问

谢谢分享

相似回答