将express node.js项目部署到azure 500服务器错误

时间:2015-04-13 16:30:56

标签: node.js azure express

似乎尝试了所有可用的解决方案,即使有些人声称Azure已在内部修复此问题,但我无法让它工作,生产部署每次都会给我500个错误。部署本地工作。这是我的app.js,它基本上是“开箱即用”的快递4.12.2

var express = require('express');
var path = require('path');
var favicon = require('serve-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');

// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.set('port', process.env.PORT || 1337);
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
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;

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

4 个答案:

答案 0 :(得分:1)

我怀疑您可能会在日志中收到此错误。

Error: ENOENT, open 'D:\home\site\wwwroot\bin\views\layouts\main.handlebars' at Error (native)

Enable the error logs

请注意views文件夹的路径。

您可以尝试删除www文件。查看Express docs中关于如何使用的最后几段。

此外,我发现如果您拥有图像和字体等资源,则需要添加app.use(express.static('public')); - 否则会无声地失败。

答案 1 :(得分:0)

确保您的入口点位于根文件夹中。

在我的情况下,我的入口点是' ./ bin / www',我不得不手动将此文件移动到root并更新Web.config中的和部分以使其正常工作。

进行这些更改后再次部署。

答案 2 :(得分:0)

以下问题提供了几个解决方案

Azure NodeJS Error: ENOENT, open 'D:\home\site\wwwroot\bin\views\'

现在我只是在app.js的顶部附近使用了以下内容 process.chdir(__目录名);

答案 3 :(得分:0)

我知道处理这种情况非常棘手。

  1. 尝试了解/ google nodejs azure门户支持哪些版本。它仅支持特定版本。记下这些版本,并尝试使用所需的任何版本,或者仅尝试使用该列表中的最新版本。
  2. 在azure门户中->转到您的应用程序服务->您应该在应用程序服务详细信息中看到控制台->输入节点-v。
  3. 这应该给您的节点版本可能像0.10.4左右。这可能是主要的罪魁祸首。
  4. 在应用服务配置下转到您的应用设置。在其中添加节点版本,例如WEBSITE_NODE_DEFAULT_VERSION作为节点版本,例如:8.9.4
  5. 转到您的package.json并添加与Azure门户应用程序设置中使用的节点版本相同的节点版本。例如:“引擎”:{ “节点”:“ 8.9.4” }
  6. 重新启动应用程序服务->检查控制台->节点-v。 如果显示的版本相同,则部署应用程序,并且应该不会出现任何问题。

如何检查实际错误而不是500

  1. 在您的应用服务的Azure门户中启用诊断日志
  2. 选择日志流
  3. 刷新您的网站。现在,您应该在日志流中看到真正的错误消息。

祝你好运。