redis hmget node.js异步/等待不起作用

时间:2019-06-22 16:32:31

标签: javascript node.js redis async-await

我正在尝试使用以下代码通过node.js从Redis获取一些数据:

var moment = require("moment");
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var crypto = require('crypto');
var redis = require('redis');
var bluebird = require("bluebird");
bluebird.promisifyAll(redis.RedisClient.prototype);
bluebird.promisifyAll(redis.Multi.prototype);


const uuidv4 = require('uuid/v4');

var KEY_USERS = "auction:users";
var KEY_ADMIN_TOKENS = KEY_USERS + ":admin_tokens";
var KEY_USER_TOKENS = KEY_USERS + ":user_tokens";
var SERVER_PORT = 12251;

var redis_client = bluebird.promisifyAll(redis.createClient({
        host: '127.0.0.1',
        no_ready_check: true,
        auth_pass: '****',
}));



redis_client.on('connect', function () {
        console.log('Redis client connected');
});

redis_client.on('error', function (err) {
        console.log('Something went wrong with Redis Connection ' + err);
});

server.listen(SERVER_PORT);

console.log('1');

(async () => {

        var response = await isAdminUser('c169024a-8902-4310-8955-ff46516e8703');

        console.log("From Async " + response);        
})()

console.log('2');

// Promise.resolve()
//         .then(() => isAdminUser('c169024a-8902-4310-8955-ff46516e8703'))
//         .then(() => console.log('3'));


console.log("Server Connected and redis initialized.");

async function isAdminUser(token) {
        return new Promise((resolve, reject) => {

                redis_client.hmget(KEY_ADMIN_TOKENS, [token, token], function (error, result) {
                        if (error) {
                                console.log(error);
                                throw error;
                        }
                        console.log("Token Result : " + result);

                        resolve(result);
                });
        });
}

现在的问题是,节点正在等待redis查询完成并前进到下一行代码。

控制台输出:

1
2
Server Connected and redis initialized.
Redis client connected
Token Result : "my result"
From Async "my result"

所需的输出:

1
2
Redis client connected    
Token Result : "my result"
From Async "my result"
Server Connected and redis initialized.

我想念/做错了什么?我经历了很多建议相同的教程/文章。

1 个答案:

答案 0 :(得分:0)

异步函数不过是返回promise的函数的语法糖,只有在函数中使用await时,才有意义使函数异步。

您的函数isAdminUser不使用await,因此不需要async。它实际上什么也没做。

此外,您正在将redis_client传递给promisifyAll,但是要使其生效,您需要在客户端中使用async方法。

我对您的代码进行了一些重构,以将客户端初始化转移到Promise:

const initializeRedisClient = () => new Promise((resolve, reject) => {
    const redis_client = bluebird.promisifyAll(redis.createClient({
        host: '127.0.0.1',
        no_ready_check: true,
        auth_pass: '****',
    }));

    redis_client.on('connect', function () {
        console.log('Redis client connected');
        resolve(redis_client);
    });

    redis_client.on('error', function (err) {
        console.log('Something went wrong with Redis Connection ' + err);
        reject(err);
    });
});

(async () => {
    const redis_client = await initializeRedisClient();
    const response = await isAdminUser(redis_client, 'c169024a-8902-4310-8955-ff46516e8703');

    console.log("From Async " + response);
    console.log("Server Connected and redis initialized.");
})()

console.log('2');

async function isAdminUser(redis_client, token) {
    const result = redis_client.hmgetAsync(KEY_ADMIN_TOKENS, [token, token]);

    console.log("Token Result : " + result);

    return result;
}