背景资料
这是我第一次尝试节点...现在是异步模块。我很难对redis数据库进行同步调用。
目标 最终,我需要发生的是当用户调用我的REST API的GET方法时,我想返回看起来像这样的json对象:
[ { '10.123': '1111111111' },
{ '10.126': '2222222222' },
{ '10.125': '3333333333' },
{ '10.222': '4444444444' },
{ '10.131.90': '5555555555' },
{ '10.18': '6666666666' },
{ '10.19': '7777777777' },
{ '10.44': '8888888888' } ]
使用主GET方法中的SCAN命令查询上面看到的键。然后对于redis SCAN返回的每个键,我转过身来运行一个“HGETGALL”命令来找出你在上面看到的值
问题
虽然在主GET方法中返回的每个键都正确调用了queryhgetall函数...但是从此方法返回的数据为空。这是我的代码:
代码
25 //async test start ====================================================================================
26 var async = require('async');
27
28 var queryhgetall = function (redis_key, doneCallBack) {
29 var tempObject = {};
30 redis.hgetall(redis_key, function (err, data) {
31 if (err) {
32 console.log("hgetall method fails: " + err);
33 }
34 if (data) {
35 var key = redis_key.split(":");
36 tempObject[key[1]]=data.callerid;
37 console.log(tempObject);
38 }
39 });
40 return doneCallBack(null,tempObject);
41 };
42
43 router.get('/', function (req, res, next) {
44 redis.send_command("SCAN", [0, "MATCH", "emergency:*"], function (err, reply) {
45 if (reply) {
46 var retdata = [];
47 async.map(reply[1], queryhgetall, function (err, results) {
48 console.log("finished");
49 console.log("results start");
50 console.log(results);
51 console.log("results stop");
52 });
53 }
54 });
55 });
56
57 //async test finish =====================================================================================================
代码输出
这是我在控制台输出中看到的内容:
GET /emergency/ - - ms - -
finished
results start
[ {}, {}, {}, {}, {}, {}, {}, {} ]
results stop
{ '10.123': '1111111111' }
{ '10.126': '2222222222' }
{ '10.125': '3333333333' }
{ '10.222': '4444444444' }
{ '10.131.90': '5555555555' }
{ '10.18': '6666666666' }
{ '10.19': '7777777777' }
{ '10.44': '8888888888' }
从输出中可以看出,第37行的console.log命令证明我已经正确查询了每个键的callerid值,但是我将这些数据返回给GET方法的方式可能不正确,因为一切都是空的。
你能告诉我我错过了什么吗?我试图按照这里的例子: http://javascriptplayground.com/blog/2013/06/think-async/答案 0 :(得分:0)
我想我明白了。我改变了这个:
28 var queryhgetall = function (redis_key, doneCallBack) {
29 var tempObject = {};
30 redis.hgetall(redis_key, function (err, data) {
31 if (err) {
32 console.log("hgetall method fails: " + err);
33 }
34 if (data) {
35 var key = redis_key.split(":");
36 tempObject[key[1]]=data.callerid;
37 console.log(tempObject);
38 }
39 });
40 return doneCallBack(null,tempObject);
41 };
到此:
28 var queryhgetall = function (redis_key, doneCallBack) {
29 var tempObject = {};
30 redis.hgetall(redis_key, function (err, data) {
31 if (err) {
32 console.log("hgetall method fails: " + err);
33 }
34 if (data) {
35 var key = redis_key.split(":");
36 tempObject[key[1]]=data.callerid;
37 console.log(tempObject);
38 return doneCallBack(null, tempObject);
39 }
40 });
41 // console.log(tempObject);
42 // return doneCallBack(null,tempObject);
43 };
答案 1 :(得分:0)
将return doneCallBack
移到另一个函数内部,如第38-39行,这样它就会在调用回调之前等待redia数据。