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)
这是我到目前为止所做的:
npm run build:ssr还有我的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}`);
});
我究竟做错了什么?
谢谢你的帮助。
使用dist文件夹作为存档而不是dist文件夹的内容。
在您的弹性 beanstalk 配置中设置以下“节点命令”设置。
node dist/server
这应该允许您使用标准的 Angular 开箱即用设置在本地和 AWS EB 上运行。
编辑 只是为了提供更多信息,这应该可以解决问题。正如@Kartik Chandra 指出的,问题出在server.ts文件中
const distFolder = join(process.cwd(), 'dist/landing/browser');
在您的 prod env 进程上部署时,将查找dist文件夹,因此如果您不复制它,它将失败。
选项是复制整个 dist 文件夹或更改您的 server.ts,但这会破坏您的本地开发。
同时,我找到了部署在 Elastic Beanstalk 上的解决方案。
下面是我所做的不同步骤:
Software Configuration中,通过更改 Node 命令来编辑node dist/server.js 
编辑nodejs使用的端口(2个选项):
A。您只需将文件中的端口编辑server.ts为8081即可(对应于nginx默认配置中使用的nodejs端口)
const PORT = process.env.PORT || 8081;
b. 或者您可以使用配置文件 .ebextensions编辑 nginx 配置,以匹配 Angular 通用应用程序中使用的端口(默认情况下为 4000)
| 归档时间: | 
 | 
| 查看次数: | 4463 次 | 
| 最近记录: |