0

我遇到了这种奇怪的情况,我的 Cron 作业成功执行了一个返回承诺的函数,但是,当它尝试.find()在模型上执行 a 时,它实际上从未执行过。我在我的应用程序的其他地方使用了相同的函数,并且通过 API 调用调用并且没有返回问题。有什么我想念的吗?

这是我的 cron 脚本:

var CronJob = require('node-cron');
var TradeService = require('../services/TradeService');

// Setup the cron job to fire every second
CronJob.schedule('* * * * * *', function() {
  console.log('You will see this message every second');
  TradeService.executePendingTrades();

}, null, true, 'America/Los_Angeles');

以下是被调用的相关函数:

exports.executePendingTrades = () => {

  // Get all pending trades
  exports.getPendingTrades().then(results => {
    console.log('results', results); // This never fires
  })
}

exports.getPendingTrades = () => {
  return new Promise((resolve, reject) => {

    Trades.find({})
      .where('is_canceled').equals('false')
      .where('is_completed').equals('false')
      .sort('-created_at')
      .exec( (err, payload) => {
        if (err) {
          return reject(err); // This never fires
        }
        return resolve(payload); // This never fires
      })
  });
}
4

1 回答 1

2

这是在黑暗中拍摄的,但请确保您在 CRON 作业中启动数据库连接。否则您将无法执行任何查询。

于 2018-01-23T21:06:28.477 回答