0
function Redis(){

this.redis=require('redis-node');
this.client =this.redis.createClient(6377, '127.0.0.1', {detect_buffers: true});
this.client.auth("pwd");

}

module.exports=Redis;

Redis.prototype.setKeyValue=function(key,value){

var obj=this;
this.client.get(key,function(err,res){

    if(res==null){


        obj.client.set(key,value,function (err, result) {
            console.log(result); 
            obj.client.quit();//here im getting error as client doesn't have method quit
         });

    }
    else{

        console.log('Sorry!!!key is already exist');
    }
});


  };
4

2 回答 2

0

NodeJS 的首选库是 inded node_redis。此外,您的代码没有受到竞争条件get的保护(set密钥可能set来自另一个进程),希望 Redis 提供一个命令:setnx

最后,您的代码可以简化为:

var redis = require("redis");

function Redis() {
  this.client = redis.createClient(6377, '127.0.0.1', {
    detect_buffers: true,
    auth_pass: "pwd"
  });
}

/**
 * @param {String} key   key name
 * @param {String} value key value
 * @param {Function} f(err, ret)
 */
Redis.prototype.setKeyValue = function(key, value, f) {
  this.client.setnx(key, value, f);
};

module.exports = Redis;

但是我不明白为什么你不直接使用 redis 客户端 api 而不是将它包装在 Redis 函数中?

于 2013-09-03T12:46:03.417 回答
0

终于我知道了

https://github.com/bnoguchi/redis-node

在上面的库中,客户端没有一个名为 client.quit() 的方法,我们可以使用 client.close()。

https://github.com/mranney/node_redis

这里它有一个名为 quit 的方法来关闭连接。

于 2013-09-02T08:55:51.693 回答