NodeJS 使用redis实现定时执行任务


文章目录

  • NodeJS 使用redis实现定时执行任务
  • 场景
  • 使用Redis定时器解决
  • Redis定时器
  • Redis发布订阅
  • 操作
  • nodejs代码
  • 主意事项


场景

  • 用户下订单后,需要在5分钟内完成支付,否则订单关闭;
  • 用户在完成订单后,如果没有评论,过一星期,系统自动评论,并完结。
  • 设值预约定时发送消息

使用Redis定时器解决

Redis定时器

Redis中有一个expire命令,用来设置key的过期时间。使用发布订阅,可以接收到key的过期提醒,当key过期时,再执行相关业务逻辑。

127.0.0.1:6379> set test tom EX 10
OK
127.0.0.1:6379> get test
(nil)

设置test(key)的过期时间为10秒,10秒过后key自动销毁。

Redis发布订阅

Redis发布订阅(pub/sub)是一种消息模式,发送者(pub)发送消息,订阅者(sub)接收消息。

Redis客户端可以订阅任意数量的频道。

用一张图来展示频道(channel1)与订阅者(client2, client5, client1)的关系:

redis定时任务java redis定时任务有效时间_redis定时任务java

当有消息发布时,他们的关系

redis定时任务java redis定时任务有效时间_Redis_02

redis的key过期通知也是基于发布订阅模型的。不同的是订阅频道是固定的__keyevent@0__:expired,当然,redis还有好多类似与这种特定频道的通知,想了解更多,可以看这里Redis键空间通知。

操作

1、Windows 操作系统下,在redis程序根目录打开命令行窗口执行以下命令 开启对过期删除key 通知功能

./redis-cli config set notify-keyspace-events Ex

nodejs代码

var redis = require("redis");  
var client = redis.createClient(6379, "127.0.0.1");  
var client1 = redis.createClient(6379, "127.0.0.1");

function getRedisData() {  
    //客户端连接redis成功后执行回调
    client.on("ready", function () {
        //订阅消息
        client.subscribe("chat");
        client.subscribe("chat1");
        console.log("订阅成功。。。");
    });

    client.on("error", function (error) {
        console.log("Redis Error " + error);
    });

    //监听订阅成功事件
    client.on("subscribe", function (channel, count) {
        console.log("client subscribed to " + channel + "," + count + "total subscriptions");
    });

    //收到消息后执行回调,message是redis发布的消息
    client.on("message", function (channel, message) {
        console.log("我接收到信息了" + message);
        //在这里收到消息,处理业务逻辑
    });

    //监听取消订阅事件
    client.on("unsubscribe", function (channel, count) {
        console.log("client unsubscribed from" + channel + ", " + count + " total subscriptions")
    });
}

主意事项

由于开启了消息订阅通道的 redis通信信道的客服端连接,不能做其他操作,比如 增加、删除、修改操作,需要其他的redis连接对象去操作。