Azure 托管节点应用找不到模块 'async/each'

Azure hosted node app cannot find module 'async/each'

我已经将我的应用程序部署到 Azure 几个星期了,现在没有任何问题。但是,现在我已经将数据库集成到后端,它抛出了日志流中看到的这个错误,并给浏览器一个 500 代码。

Application has thrown an uncaught exception and is terminated: Error: Cannot find module 'async/each' at Function.Module._resolveFilename (module.js:325:15) at Function.Module._load (module.js:276:25) at Module.require (module.js:353:17) at require (internal/module.js:12:17) at Object.<anonymous> (D:\home\site\wwwroot\node_modules\mongoose\lib\schema.js:11:12) at Module._compile (module.js:409:26) at Object.Module._extensions..js (module.js:416:10) at Module.load (module.js:343:32) at Function.Module._load (module.js:300:12) at Module.require (module.js:353:17) at require (internal/module.js:12:17)

Mongoose 似乎是问题所在,所以当我排除它时,一切又好了。我尝试将 async-each 作为依赖项包含在我的 package.json 中,但这没有帮助(我之前没有看到带有 / in 的模块,所以在这里猜测)

同样在绝望的时刻,我尝试将同一个应用程序推送到另一个 Web 应用程序服务,但它甚至无法部署。 WebApiClient 超时 - 不管是什么意思。

我向 Heroku 部署了完全相同的应用程序,它运行良好。

"use strict";
let express = require('express');
let path = require('path');
let favicon = require('serve-favicon');
let logger = require('morgan');
let cookieParser = require('cookie-parser');
let bodyParser = require('body-parser');
let mongoose = require('mongoose');
let passport = require('passport');
let LocalStrategy = require('passport-local').Strategy;
let session = require('express-session');

//routes
let home = require('./routes/index');
let register = require('./routes/register');
let members = require('./routes/members');
let login = require('./routes/login');
let logout = require('./routes/logout');

let app = express();

app.locals.courses = require('./data/courses');

// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
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(session({secret:'anything'}));
app.use(passport.initialize());
app.use(passport.session());

//mongoose passport config

require('./db').then(mongoose => {
  mongoose.Promise = global.Promise;
  require('./models/user').then(User => {
    passport.use(new LocalStrategy(User.authenticate()));
    passport.serializeUser(User.serializeUser());
    passport.deserializeUser(User.deserializeUser());
  });
})


//allow CORS requests
app.use(function (req, res, next) {
  res.header("Access-Control-Allow-Origin", "*");
  res.header("Access-Control-Allow-Headers", "X-Requested-With");
  next();
});

app.use('/', home);
app.use('/register', register);
app.use('/members', members);
app.use('/login', login);
app.use('/logout', logout);

// 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.send(err.message);
  });
}

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


module.exports = app;

mongoose成功部署到Azure,测试代码也运行良好。也许您的应用程序将使用在 package.json 文件的 devDependencies 部分中配置的任何 module。

作为生产网络服务器的 Azure Web 应用程序,如果您通过 git 部署您的应用程序,默认情况下部署任务将 运行 npm install --production,这将忽略依赖项发展 mod。

所以,你可以尝试按照Custom Deployment Script生成node.js和mod的部署脚本,在deploy.cmd中找到句子call :ExecuteCmd !NPM_CMD! install --production和mod化为call :ExecuteCmd !NPM_CMD! install.

同时,您可以按照https://docs.microsoft.com/en-us/azure/nodejs-specify-node-version-azure-apps升级您的node.js和npm版本的Azure Web Apps'运行时间,以避免嵌套node_modules文件夹结构。