A. java web开发缓存方案,ehcache和redis哪个更好
这里就不再逐个讨论了,我将会在一个实际应用程序开发场景中介绍其中的一些。使用Redis作为一个缓存解决方案我之前提到过,Redis可轻易地用作一个缓存解决方案,碰巧我现在正好需要这样一个!在该应用程序示例中,我将Redis集成到我基于定位的移动Web服务中,称之为Magnus。如果您没有关注本系列,那么我会先使用Play框架实现Magnus,从那时起我就已经在各种实现中开发和重构它了。Magnus是一个简单服务,可以通过HTTPPUT请求使用JSON文档。这些文档描述了特定帐号的位置,表示持有移动设备的人。现在,我想要将缓存集成到Magnus,也就是说我想要通过将不常更改的数据存储在内存中以减少I/O流量。Magnus缓存!在清单5中的第一步中,可以通过get调用了解新引入的帐户名称(一个键)是否为REdis中的一个键。get调用可以将帐户ID作为一个值返回,或者将返回null。如果返回一个值,我将用其作为我的acctId变量。如果返回的是null(表明该帐户名称不是Redis中一个键),那么我将在MongoDB查找该帐户值,并通过set命令将其添加到Redis。这里的优势是速度:接下来,被请求的帐户将提交一个位置,这样我就能够从Redis中获取其ID(作为内存缓存),而不是转到MongoDB并带来额外读取I/O成本。清单5.使用Redis作为内存缓存"/location/:account"{put{defjacksonMapper=newObjectMapper()defjson=jacksonMapper.readValue(request.contentText,Map.class)defformatter=newSimpleDateFormat("dd-MM-yyyyHH:mm")defdt=formatter.parse(json['timestamp'])defres=[:]try{defjedis=pool.getResource()defacctId=jedis.get(request.parameters['account'])if(!acctId){defacct=Account.findByName(request.parameters['account'])jedis.set(request.parameters['account'],acct.id.toString())acctId=acct.id}pool.returnResource(jedis)newLocation(acctId.toString(),dt,json['latitude'].doubleValue(),json['longitude'].doubleValue()).save()res['status']='success'}catch(exp){res['status']="error${exp.message}"}response.json=jacksonMapper.writeValueAsString(res)}}注意,清单5中的aMagnus实现(使用Groovy编写)仍然使用一个NoSQL实现作为数据模型存储;它仅仅使用Redis作为一个缓存实现用于查询数据。因为我的主要帐户数据位于MongoDB中(事实上,它驻留在MongoHQ.com中),而我的Redis数据存储在本地运行。在随后查找帐户ID时,Magnus速度将显着提升。可是等等!我为什么同时需要MongoDB和Redis?难道我就不能单独使用一个吗?ORM的Node.js很多项目均提供ORM类映射用于Redis,其中包括一个极富影响力的基于Ruby的备用方案,称为Ohm。我检查了该项目基于Java的派生产品(称为JOhm),但是最终决定使用一个为Node编写的派生产品。Ohm及其派生项目的妙处在于他们允许您将一个对象模型映射到一个基于Redis的数据结构。因此,您的模型对象是持久性的,同时在大多数情况下其读取速度也非常之快。有了Nohm,我便能够使用JavaScript快速重写我的Magnus应用程序并能立即持久化Location对象。在清单6中,我已定义了一个Location模型,该模型包括3个属性。(注意,我通过将timestamp设置为一个字符串而不是一个真实的时间戳,从而简化我的示例。)清单6.Node.js中的RedisORMvarLocation=nohm.model('Location',{properties:{latitude:{type:'float',unique:false,validations:[['notEmpty']]},longitude:{type:'float',unique:false,validations:[['notEmpty']]},timestamp:{type:'string',unique:false,validations:[['notEmpty']]}}});Node的Express框架使NohmLocation对象的使用变得十分简单。在我的应用程序PUT实现中,我可以捕获正在进入的JSON值,并通过Nohm的p调用将其导入到一个Location实例。然后我再检查该示例是否有效,如果有效,我会对其进行持久化。清单7.在Node的Express.js中使用Nohmapp.put('/',function(req,res){res.contentType('json');varlocation=newLocation;location.p("timestamp",req.body.timestamp);location.p("latitude",req.body.latitude);location.p("longitude",req.body.longitude);if(location.valid()){location.save(function(err){if(!err){res.send(JSON.stringify({status:"success"}));}else{res.send(JSON.stringify({status:location.errors}));}});}else{res.send(JSON.stringify({status:location.errors}));}});正如清单7所示,可以轻易地将Redis构建成一个极其快速的内存数据存储。在一些案例中,它甚至是一个比memcached更好的缓存!结束语Redis对于许多数据存储场景非常有用,因为它可以将数据持久化到磁盘(还因为它支持一个丰富的数据集),有时候,它是memcached的有力竞争对手。有些情况下,对于您的领域也是很有意义的,您可以使用Redis作为数据模型和队列的一个备份存储。Redis客户端实现几乎可被移植到任何编程语言中。Redis不是RDMBS的完全替代品,也不是一个重量级存储,但是和MongoDB一样拥有丰富的功能。然而,在很多情况下,它可与这些技术共存。
B. 用Java开发Web程序怎么使用缓存
默认情况下。Java并不完成缓存,要安装圆首URL类使用系统级缓存,需岩薯要有:
ResonseCache的一个具体子类。
CacheRequest的一个具体子类。
CacheResponse的一个具体子类。橘枣数
C. java为什么使用缓存实现抢答
您是否在询问为什么使用缓存,缓存是用来存储数据的。
FIFO先入先出,很好理解,就和队列一样,先进队列的先出队列,LRU 最近最少使用,意思就是最近读取的数据放在最前面,最早读取的数据放在最后面,如果这个时候有新的数据进来,那么最后面存储的数据淘汰,LFU最不常使用,意思就是对存储的数据都会有一个计数引用,然后队列按数据引用次数排序,引用数多的排在最前面,引用数少的排在后面。如果这个时候有新的数据进来,把最后面的数据删除,把新进数据排在最后面,且引用次数为1。
D. Java的应用缓存cache如何入门
Java的应用缓存cache入门:
java常用的缓存有:ehcache, oscache,jcache,这些cache都是单机的,即存在本机的内存中,另外分布式的cache我用过memcache,它被独立部署在一台服务器上,可以实现多个客户端共用缓存;
一般用到缓存的场景:
1.在处理并发请求,需要及时响应的。
2.加快系统响应速度。举个例子:比如购物网站有 售卖物品的排行榜,这种数据都是由数据库中N多表关联查询排序得到的,那么就可以存在缓存当中,当页面请求查看排行榜时直接取缓存中的数据。后台定时任务根据一定的时间间隔计算好排行结果,再替换到当前缓存中。
这就是一个简单的缓存应用示例。