‘壹’ java目前比较常用的缓存有哪些 集中式缓存与分布式缓存有何区别 它们应用场景是
这个得顶一个,我也很想了解
‘贰’ Java中缓存的问题,session,hibernate的缓存,二级缓存,以及我们把常用的的数据缓存下来,有什么分别
sessiono由session工厂创建,是一个非常重要的对象,它可以开启事务(业务中必须用到的),对数据进行增删改查,创建hql,创建原生sql,创建qbc,等,主要是跟数据库一级to,po,do对象打交道。
首先设置缓存的目的就是为了减少服务器压力提高用户访问速度。换才能就好像是我们的内存一样,而数据库就好像我们的硬盘一样,从内存中拿数据肯定要比从硬盘中拿数据快的多。
一级缓存又名session级缓存,就是hibernate查询数据库后将查询结果存放在缓存中,这样下一次查询相同数据时就不会从数据库中拿数据,就可以直接在缓存中拿数据,加快了访问速度。因为从数据库中拿数据时费时费力的所以有了缓存就大大减小了服务器压力。
hibernate支持二级缓存,但是需要第三方插件。需要手动开启,二级缓存要比一级缓存范围大。我说的范围大是指生存周期大。通常存放一些访问频率高但是需要更改的次数少的数据。它的存放位置是在本地的某个文件夹下(存储位置可以通过配置文件设置)。
说白了有了缓存我们访问数据就会很快,减少了服务器压力。
‘叁’ JAVA几种缓存技术介绍说明
1、TreeCache / JBossCache
JBossCache是一个复制的事务处理缓存,它允许你缓存企业级应用数据来更好的改善性能。缓存数据被自动复制,让你轻松进行JBoss服务器之间 的集群工作。JBossCache能够通过JBoss应用服务或其他J2EE容器来运行一个MBean服务,当然,它也能独立运行。
2、WhirlyCache
Whirlycache是一个快速的、可配置的、存在于内存中的对象的缓存。它能够通过缓存对象来加快网站或应用程序的速度,否则就必须通过查询数据库或其他代价较高的处理程序来建立。
3、SwarmCache
SwarmCache是一个简单且有效的分布式缓存,它使用IP multicast与同一个局域网的其他主机进行通讯,是特别为集群和数据驱动web应用程序而设计的。SwarmCache能够让典型的读操作大大超过写操作的这类应用提供更好的性能支持。
4、JCache
JCache是个开源程序,正在努力成为JSR-107开源规范,JSR-107规范已经很多年没改变了。这个版本仍然是构建在最初的功能定义上。
5、ShiftOne
ShiftOne Java Object Cache是一个执行一系列严格的对象缓存策略的Java lib,就像一个轻量级的配置缓存工作状态的框架。
‘肆’ Java的应用缓存cache如何入门
跟session不是一个概念,简单的谈下我个人对缓存的看法吧,你可以把它想象成一个容量大的hashMap,可以往里面get set数据,由于数据存在内存当中而不是数据库中,所以存取速度较快。
java常用的缓存有:ehcache, oscache,jcache,这些cache都是单机的,即存在本机的内存中,另外分布式的cache我用过memcache,它被独立部署在一台服务器上,可以实现多个客户端共用缓存。
一般用到缓存的场景:1.在处理并发请求,需要及时响应的。2.加快系统响应速度。举个例子:比如购物网站有 售卖物品的排行榜,这种数据都是由数据库中N多表关联查询排序得到的,那么就可以存在缓存当中,当页面请求查看排行榜时直接取缓存中的数据。后台定时任务根据一定的时间间隔计算好排行结果,再替换到当前缓存中。 这就是一个简单的缓存应用示例。
具体用法你可以参考 各个缓存的说明文档,网络一下很多的。 纯手打,望采纳~