主管节点.js"程序节点应用退出,代码为0"错误

时间:2014-06-18 14:55:28

标签: node.js express supervisor

当我安装快速脚手架应用程序时

express

然后运行npm install

npm install

然后运行主管

supervisor app

我得到了

Starting child process with 'node app'
Program node app exited with code 0

app.js文件是一个基本的默认快递实例。

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes/index');
var users = require('./routes/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);

/// catch 404 and forward to error handler
app.use(function(req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

/// error handlers

// development error handler
// will print stacktrace
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
        });
    });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});


module.exports = app;

3 个答案:

答案 0 :(得分:19)

生成器创建的应用调用./bin/www,其中包含app.js,然后开始侦听流量。

app.js 本身不会这样做

我认为这很重要。

app.listen在<{1}}中调用 ,但在app.js中调用...这就是您获得./bin/www结果的原因。当你调用exit 0而不是app.js时,它会运行该文件,但由于没有监听流量的命令,程序正常结束...即。没有做任何事情。

那就是说,你有两个选择..

选项1

如果您有./bin/www个文件,则可以运行./bin/www来开始使用。

选项2

如果由于某种原因您没有supervisor ./bin/www文件,则可以将您的应用文件编辑为如下所示。

在您的应用列表中,替换

./bin/www

用这个

module.exports = app;

重要提示

虽然该编辑将启动应用程序监听,并且您将不再获得app.set('port', process.env.PORT || 3000); var server = app.listen(app.get('port'), function() { debug('Express server listening on port ' + server.address().port); }); ,但我不能保证如果缺少其他文件和目录,应用程序不会因某些其他错误而崩溃。例如,如果exit 0目录不存在,则需要routesroutes/index的声明将失败,并且会发生其他不良事件。

答案 1 :(得分:0)

使用 express-generator 时,运行应用的默认方式是粘贴

DEBUG={appName}:* npm start

{appName} - 可能是您的文件夹名称(就像我一样),无论如何,您可以在 package.json - &gt;中找到它。 “名称”

答案 2 :(得分:-2)

感谢您的最佳答案,最后这对我有用:

"main": "./bin/www",
"scripts": {
   "start": "node ./bin/www"
}