2016-05-09 3 views
1

Я новичок в Nodejs и Expressjs. Я думаю, что сценарий работает постоянно в фоновом режиме, не прерывая приложение. Существует множество графических модулей NodeJs (таких как планирование узлов, позже и т. Д.), Но я не мог понять, как включить их в мое приложение ExpressJs.Как добавить модуль node-schedule в приложение expressjs

Кроме того, где я должен включать этот модуль; на уровне приложения или на маршрутизаторе.

Надеюсь, что окружающая среда не является проблемой, я запускаю это приложение на 32-битной коробке Windows 7.

Я использовал генератор Yeoman для создания приложения ExpressJs. Копирование и вставка кода из файлов, сгенерированных генератором.

config.js

var path = require('path'), 
rootPath = path.normalize(__dirname + '/..'), 
env = process.env.NODE_ENV || 'development'; 

var config = { 
    development: { 
    root: rootPath, 
    app: { 
     name: 'nodejswebsocketapp' 
    }, 
    port: process.env.PORT || 3000, 
    }, 

    test: { 
    root: rootPath, 
    app: { 
     name: 'nodejswebsocketapp' 
    }, 
    port: process.env.PORT || 3000, 
    }, 

    production: { 
    root: rootPath, 
    app: { 
     name: 'nodejswebsocketapp' 
    }, 
    port: process.env.PORT || 3000, 
    } 
}; 

module.exports = config[env]; 

express.js

var express = require('express'); 
var glob = require('glob'); 

var favicon = require('serve-favicon'); 
var logger = require('morgan'); 
var cookieParser = require('cookie-parser'); 
var bodyParser = require('body-parser'); 
var compress = require('compression'); 
var methodOverride = require('method-override'); 
var allowCrossDomain = function(req, res, next) { 
    res.header('Access-Control-Allow-Origin', '*'); 
    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE'); 
    res.header('Access-Control-Allow-Headers', 'X-Requested-With, Content-Type'); 
    next(); 
} 

module.exports = function(app, config) { 
    var env = process.env.NODE_ENV || 'development'; 
    app.locals.ENV = env; 
    app.locals.ENV_DEVELOPMENT = env == 'development'; 

    app.set('views', config.root + '/app/views'); 
    app.set('view engine', 'jade'); 

    // app.use(favicon(config.root + '/public/img/favicon.ico')); 
    app.use(logger('dev')); 
    app.use(bodyParser.json()); 
    app.use(bodyParser.urlencoded({ 
    extended: true 
    })); 
    app.use(cookieParser()); 
    app.use(compress()); 
    app.use(express.static(config.root + '/public')); 
    app.use(methodOverride()); 
    app.use(allowCrossDomain); 

    var controllers = glob.sync(config.root + '/app/controllers/*.js'); 
    controllers.forEach(function (controller) { 
    require(controller)(app); 
    }); 

    app.use(function (req, res, next) { 
    var err = new Error('Not Found'); 
    err.status = 404; 
    next(err); 
    }); 

    if(app.get('env') === 'development'){ 
    app.use(function (err, req, res, next) { 
     res.status(err.status || 500); 
     res.render('error', { 
     message: err.message, 
     error: err, 
     title: 'error' 
     }); 
    }); 
    } 

    app.use(function (err, req, res, next) { 
    res.status(err.status || 500); 
     res.render('error', { 
     message: err.message, 
     error: {}, 
     title: 'error' 
     }); 
    }); 

}; 

app.js

var express = require('express'); 
var config = require('./config/config'); 

var app = express(); 
var expressWs = require('express-ws')(app); 

require('./config/express')(app, config); 

app.listen(config.port, function() { 
    console.log('Express server listening on port ' + config.port); 
}); 

После этого контроллер фи ле, что я создал scheduleTaskController.js

var express = require('express'), 
    router = express.Router(), 
    schedule = require('node-schedule'); 

module.exports = function (app) { 
    app.use('/', router); 
    app.use('/schedule', router); 
}; 

router.get('/schedule', function (req, res, next) { 

    console.log(schedule.RecurrenceRule()); 

    var rule = new schedule.RecurrenceRule(); 
    rule.second = 30; 
    schedule.scheduleJob(rule, function(){ 
     console.log(new Date(), 'The 30th second of the minute.'); 
    }); 

}); 

Удар по URL урожайности '/ график' в ничто. не в браузере, а не в командной строке, где я ожидаю результат console.log.

+0

Я понял, что с моим кодом ничего не случилось. Я не понял, как работает модуль узла-расписания. 'rule.second = 30;' означает, что функция будет выполняться на 30-й секунде каждую минуту вместо запуска каждые 30 секунд. – Rajkaran07

ответ

0

Я бы создал папку сценариев, а затем потребовал, чтобы этот файл из вашего файла server.js.

+0

Я уже это делаю. Я добавил фрагменты кода в свой вопрос. Я не могу понять, что не так с моим кодом. – Rajkaran07