NodeJS动态服务加载器&跑步者

时间:2017-06-06 11:37:11

标签: node.js service cron long-running-processes

上下文

我试图为我活跃的频道构建一些闲聊/通知服务,成为 cheap-skate 财务精明的人,我是,我&# 39; d喜欢使用免费服务(追踪Heroku帐户或类似产品),因此我希望能够在单个实例上运行多个服务。

我已经创建了一个通用运行器,它应该基于一个配置,并能够获取一些节点模块并为它们提供配置设置。

我使用以下node_modules:

  

" auto-loader":" ^ 0.2.0",       " node-cron":" ^ 1.2.0",       " read-yaml":" ^ 1.1.0"

config.yml

foo: 
  cron: 1 * * * *
  url: http://www.foo.com
  team: 
    - 
      slackId: bar
      bnetId: 1
      eloId: 1
    - 
      slackId: baz
      bnetId: 2
      eloId: 2

app.js

const autoLoader = require('auto-loader');
const readYaml = require('read-yaml');
const cron = require('node-cron');

const services = autoLoader.load(__dirname +'/services')

readYaml('config.yml', function(err, conf) {

    if (err) throw err;

    Object.keys(conf).forEach(function (key) {

        console.log('Creating CRON for ' + key);

        if(cron.validate(conf[key].cron)) {             

            console.log(conf[key].cron, '-> is valid cron');

            // the cron task below does not seem to fire ever
            cron.schedule(conf[key].cron, function(){
                services[key](conf[key]);
            });

        } else {
            console.log('Cron invalid for::' + key)
        }

    }); 
});

服务/ foo.js

module.exports = function (config) {
    console.log('foo entered!!');
    console.log(config)
}

问题:

我错过了什么?如果我删除了cron计划,我的服务就会受到影响,因此我的假设如下......

要么我在概念上遗漏了一些关于运行过程在NodeJS中运行多长时间的事情(因为这是我的第一次),或者我错过了一个超级(不明显)的bug。

如何使用单独的预定代码段/任务在NodeJS中创建长时间运行的任务/进程?

1 个答案:

答案 0 :(得分:1)

代码本身按预期工作。问题似乎与cron的配置有关。

cron: 1 * * * *将在1小时后运行。

cron: "*/1 * * * *"      # would run it every minute
cron: "*/5 * * * *"      # would run it every 5 minutes
cron: "*/10 * * * * *"   # would run every 10 seconds