redis消息上的异步操作

时间:2017-07-28 07:47:35

标签: node.js mongodb asynchronous mongoose redis

我正在尝试在redis客户端发布消息时更新mongoose模型。

这就是我正在做的工作

redisClient.on('message', (channel, message) => {
let data=  JSON.parse(message);

console.log(message);

let user_id = data.user_id;
let story_id = data.story_id;

let ratingDetails = data.ratingDetails;

User.findById(user_id, (err, user) => {
    if(err) return console.error(err);

    user.rating += (ratingDetails.polarity * ratingDetails.rating);

    console.log(ratingDetails);

    console.log(user.rating);

    user.save((err) => {
        if(err) return console.error(err);
    });
});

Story.findById(story_id, (err, story) => {
    if(err) return console.error(err);

    story.totalRating += (ratingDetails.polarity * ratingDetails.rating);

    story.save((err) => {
        if(err) return console.error(err);
    });
});

});

console.log(消息)显示已传递的消息,但未执行任何mongoose操作。模型没有更新。

我第一次使用redis。这是一个好方法还是有其他替代方案?

1 个答案:

答案 0 :(得分:0)

我已经得到了解决方案,我在另一个节点进程中执行所有redis工作,因此redis进程中没有Mongo连接。

我刚刚在redis进程中创建了另一个连接并解决了问题。