Angular Universal (SSR) 错误:无法在视图目录中查找视图“索引”

Joh*_*Rin 8 amazon-elastic-beanstalk angular-universal angular

我想在 aws 上部署我的 angular 通用应用程序。

根据我的理解,我只能在弹性 beanstalk 上部署我的应用程序,因为它需要一个 Web 服务器才能运行。(这意味着没有 S3 部署)。

当我部署我的应用程序时,出现以下错误:

错误:在 ServerResponse.render (/ var/app/current/server.js:131120:7) at /var/app/current/server.js:138:9 at Layer.handle [as handle_request] (/var/app/current/server.js:124007 :5) 在下一个 (/var/app/current/server.js:123755:13) 在 Route.dispatch (/var/app/current/server.js:123730:3) 在 Layer.handle [as handle_request] ( /var/app/current/server.js:124007:5) at /var/app/current/server.js:123230:22 at param (/var/app/current/server.js:123303:14) at param (/var/app/current/server.js:123314:14)

这是我到目前为止所做的:

  1. 在我的 angular 项目中,使用命令创建生产版本 npm run build:ssr
  2. 创建我的 dist 目录的存档
  3. 在 Elastic Beanstalk 上,使用 node.js 创建一个新应用程序并上传我的存档

还有我的server.ts文件:

import 'zone.js/dist/zone-node';
import 'reflect-metadata';
import { enableProdMode } from '@angular/core';
// Express Engine
import { ngExpressEngine } from '@nguniversal/express-engine';
// Import module map for lazy loading
import { provideModuleMap } from '@nguniversal/module-map-ngfactory-loader';

import * as express from 'express';
import { join } from 'path';

// Faster server renders w/ Prod mode (dev mode never needed)
enableProdMode();

// Express server
const app = express();

const PORT = process.env.PORT || 4000;
const DIST_FOLDER = join(process.cwd(), 'dist/browser');

// * NOTE :: leave this as require() since this file is built Dynamically from webpack
const { AppServerModuleNgFactory, LAZY_MODULE_MAP } = require('./dist/server/main');

// Our Universal express-engine (found @ https://github.com/angular/universal/tree/master/modules/express-engine)
app.engine('html', ngExpressEngine({
  bootstrap: AppServerModuleNgFactory,
  providers: [
    provideModuleMap(LAZY_MODULE_MAP)
  ]
}));

app.set('view engine', 'html');
app.set('views', DIST_FOLDER);

// Example Express Rest API endpoints
// app.get('/api/**', (req, res) => { });

// Server static files from /browser
app.get('*.*', express.static(DIST_FOLDER, {
  maxAge: '1y'
}));

// All regular routes use the Universal engine
app.get('*', (req, res) => {
  res.render('index', { req });
});

// Start up the Node server
app.listen(PORT, () => {
  console.log(`Node Express server listening on http://localhost:${PORT}`);
});
Run Code Online (Sandbox Code Playgroud)

我究竟做错了什么?

谢谢你的帮助。

Woo*_*ody 6

使用dist文件夹作为存档而不是dist文件夹的内容。

在您的弹性 beanstalk 配置中设置以下“节点命令”设置。

node dist/server
Run Code Online (Sandbox Code Playgroud)

这应该允许您使用标准的 Angular 开箱即用设置在本地和 AWS EB 上运行。

编辑 只是为了提供更多信息,这应该可以解决问题。正如@Kartik Chandra 指出的,问题出在server.ts文件中

const distFolder = join(process.cwd(), 'dist/landing/browser');
Run Code Online (Sandbox Code Playgroud)

在您的 prod env 进程上部署时,将查找dist文件夹,因此如果您不复制它,它将失败。

选项是复制整个 dist 文件夹或更改您的 server.ts,但这会破坏您的本地开发。


Joh*_*Rin 2

同时,我找到了部署在 Elastic Beanstalk 上的解决方案。

下面是我所做的不同步骤:

  1. 在您的Elastic Beanstalk 应用程序Software Configuration中,通过更改 Node 命令来编辑node dist/server.js 软件配置
  2. 编辑nodejs使用的端口(2个选项):

    A。您只需将文件中的端口编辑server.ts8081即可(对应于nginx默认配置中使用的nodejs端口)

    const PORT = process.env.PORT || 8081;
    
    Run Code Online (Sandbox Code Playgroud)

    b. 或者您可以使用配置文件 .ebextensions编辑 nginx 配置,以匹配 Angular 通用应用程序中使用的端口(默认情况下为 4000)