众所周知
redis量个强大的缓存组件,可以部署在win32和linux环境之上,它有五大存储结构,其中有一种为列表list,它可以实现quene和stack的功能,即队列和堆栈的功能。
redis相关文章,可以看我的相关博文《Redis学习笔记~目录》,redis实现消息队列,可以看我的《Redis实现消息队列比MSMQ更方便》
node-redis-client相关下载地址为:https://github.com/fictorial/redis-node-client
说一下它们工作流程:
node之前
client->IIS/apache服务器->2M Thread->redis server(windows/linux)
node之后
client->Node.JS(event driven)->redis server(windows/linux)
我们可以看到,nodeJS出现之后,我们在与redis通讯时,不走原来的那种线程机制,而是走事件驱动,原来的IO瓶颈没有了,原来8G内存支持4000个并发量,现在不存在了,看到了这些信息,我想,对于高并发模块,咱们没有理由不使用nodeJS作为http服务器了吧,呵呵。
说干就干(下载地址)
首先找到\redis-node-client-master\examples目录,运行命令node publisher.js
这时打开你的redis服务redis-server,我们用的是windows版的
这时,你的redis-server将到监视到由node.js发过来的数据,如图
下面我们再来看一下通过客户端访问node.js进行redis存储的过程
如果你的电脑处于联网状态,那么安装可以把redis-node以npm模块的形式安装到node中,以后在引用时直接使用require("redis")就可以了,不需要写相对路径了,呵呵,安装它的方法如下:
npm install redis
npm install hiredis redis
这时,如果安装成功,就可以做实例了,呵呵!注意,我们的npm install redis这种安装模块的命令,是把模块安装到当前目录的,即你的工作项目如果需要redis,需要在工作项目中进行安装,如果你的工作项目目录是c:\noderedis,那么安装模块后,你的目
录会多一个node_modules文件夹,如图:
安装的过程如图:
下面我们写一个实例,用来向redis服务器发set和hset串,然后再把redis服务器里所有的键名都读出来
var redis = require("redis"); var client = redis.createClient(); client.on("error", function (err) { console.log("Error " + err); }); client.set("string key", "string val", redis.print); client.hset("hash key", "hashtest 1", "some value", redis.print); client.hset(["hash key", "hashtest 2", "some other value"], redis.print); client.hkeys("hash key", function (err, replies) { console.log(replies.length + " replies:"); replies.forEach(function (reply, i) { console.log(" " + i + ": " + reply); }); client.quit(); });
运行结果如下:
OK,这说明,我们的redis-node客户端已经和redis服务器可以正常通讯了,呵呵,下一讲中,我们将学习,通过客户端向node发post请求,将数据包通过node发到redis,敬请期待!
本文转自博客园张占岭(仓储大叔)的博客,原文链接:NodeJS系列~第三个小例子,NodeJs与Redis实现高并发的队列存储,如需转载请自行联系原博主。