8

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

express

然后运行 ​​npm install

npm install

然后运行主管

supervisor app

我明白了

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

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

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;
4

3 回答 3

19

生成器创建的应用程序调用./bin/www包括app.js然后开始侦听流量。

app.js 本身并不这样做

我认为理解这一点很重要。

app.listen没有被调用,而是app.js被调用./bin/www......这就是你得到exit 0结果的原因。当你打电话app.js而不是./bin/www它通过文件运行但因为没有命令来监听流量时,程序正常结束......即没有做任何事情。

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

选项1

如果你有一个./bin/www文件,你可以运行supervisor ./bin/www开始工作。

选项 2

./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任何消息,但我不能保证如果其他文件和目录丢失,该应用程序不会因其他错误而崩溃。例如,如果该routes目录不存在,则要求的声明将失败,routes/index并且routes/users会发生其他不好的事情。

于 2014-06-19T02:21:25.013 回答
0

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

DEBUG={appName}:* npm start

{appName}- 可能是你的文件夹名称(就像我一样),无论如何,你可以在你的package.json -> "name"中找到它;

于 2018-02-02T18:03:30.157 回答
-2

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

"main": "./bin/www",
"scripts": {
   "start": "node ./bin/www"
}
于 2016-08-03T13:39:49.920 回答