egg.js redis subscribe multiple channel

Posted chobitssp

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了egg.js redis subscribe multiple channel相关的知识,希望对你有一定的参考价值。

‘use strict‘;

function InitRedisStrategy(agent, name, channel) {
  class RedisStrategy extends agent.ScheduleStrategy {
    start() {
      // 订阅其他的分布式调度服务发送的消息,收到消息后让一个进程执行定时任务
      agent.redis.on(‘message‘, (c, message) => {
        if (c === channel) {
          this.sendOne(message)
        }
      })
    }
  }

  agent.schedule.use(name, RedisStrategy)
}

// {app_root}/agent.js
module.exports = agent => {
  // class ClusterStrategy extends agent.ScheduleStrategy {
  //   start() {
  //     // 订阅其他的分布式调度服务发送的消息,收到消息后让一个进程执行定时任务
  //     // 用户在定时任务的 schedule 配置中来配置分布式调度的场景(scene)
  //     // such as mq / redis subscribe
  //     // agent.mq.subscribe(schedule.scene, () => this.sendOne());
  //   }
  // }
  // agent.schedule.use(‘cluster‘, ClusterStrategy);

  agent.messenger.on(‘egg-ready‘, () => {
    agent.redis.subscribe(‘task1‘);
    agent.redis.subscribe(‘task2‘);
    agent.redis.subscribe(‘task3‘);
  });

  InitRedisStrategy(agent, ‘redis1‘, ‘task1‘);
  InitRedisStrategy(agent, ‘redis2‘, ‘task2‘);
  InitRedisStrategy(agent, ‘redis3‘, ‘task3‘);
};

 

以上是关于egg.js redis subscribe multiple channel的主要内容,如果未能解决你的问题,请参考以下文章

理解 Redis - Publish Subscribe 消息订阅

egg.js 24.1创建egg.js项目

创建一个egg.js项目

Node.js学习9~Egg.js框架学习和部署实战

Egg.js搭建后台服务API

使用egg.js和egg-sequelize连接mysql