NodeJs与Redis实现高并发的队列存储

众所周知

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服务器->2MThread->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目录,运行命令nodepublisher.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", "stringval", 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,敬请期待!

 

你可能感兴趣的:(node.js)