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

node.js azure express

3602 观看

4回复

726 作者的声誉

似乎尝试了所有可用的解决方案,即使有些人声称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'));
           });
作者: OliverJ90 的来源 发布者: 2015 年 4 月 13 日

回应 (4)


1

11 作者的声誉

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

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

启用错误日志

请注意views文件夹的路径。

您可以尝试删除www文件。检查Express文档中的最后几段如何。

另外我发现app.use(express.static('public'));如果你有像图像和字体这样的资源就需要添加- 否则它会无声地失败。

作者: dickie.... 发布者: 19.05.2015 09:59

0

1 作者的声誉

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

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

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

作者: nixonberg 发布者: 02.02.2017 08:08

0

21 作者的声誉

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

Azure NodeJS错误:ENOENT,打开'D:\ home \ site \ wwwroot \ bin \ views \'

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

作者: user1216891 发布者: 13.02.2017 03:17

0

2749 作者的声誉

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

  1. 尝试了解/ google nodejs azure portal支持的版本。它仅支持特定版本。请注意这些版本并尝试使用您需要的任何版本,或尝试仅使用该列表中的最新版本。
  2. 在azure portal中 - >转到您的应用服务 - >您应该在appservice详细信息中看到控制台 - >输入节点-v。
  3. 这应该给你节点版本可能像0.10.4左右。这可能是主要的主要罪魁祸首。
  4. 转到您的应用服务配置下的应用设置。在那里添加节点版本,例如WEBSITE_NODE_DEFAULT_VERSION作为节点版本ex:8.9.4
  5. 转到package.json并添加与azure portal appsettings中使用的节点版本相同的节点版本。例如:“引擎”:{“node”:“8.9.4”}
  6. 重启应用服务 - >检查控制台 - >节点-v。如果这显示相同的版本然后部署应用程序,它应该解决任何问题。

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

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

祝好运。

作者: Kurkula 发布者: 05.05.2019 05:10
32x32