这里就不再逐个讨论了,我将会在一个实际应用程序开发场景中介绍其中的一些。使用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一样拥有丰富的功能。然而,在很多情况下,它可与这些技术共存。
温馨提示:答案为网友推荐,仅供参考