您的位置:首页 > 数据库 > Redis

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

2015-11-27 14:27 1606 查看
众所周知
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,敬请期待!
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: