Kyl*_*ett 6 heroku node.js nestjs
我目前正在尝试部署由 Nest.JS CLI(从 5.3.0 版开始)生成的基本启动器模板,并且似乎在应用程序启动时超时。我想知道是否有人设法部署到 Heroku?
我不确定是否需要包含某种 Procfile?
此外,关于部署 Nest.JS 的信息似乎并不多
我尝试部署时的 Heroku 日志。
heroku[web.1]: Starting process with command `npm start`
app[web.1]:
app[web.1]: > testy@0.0.0 start /app
app[web.1]: > ts-node -r tsconfig-paths/register src/main.ts
app[web.1]:
app[web.1]: [Nest] 21 - 2018-10-16 06:52:17 [NestFactory] Starting Nest application...
app[web.1]: [Nest] 21 - 2018-10-16 06:52:17 [InstanceLoader] AppModule dependencies initialized +21ms
app[web.1]: [Nest] 21 - 2018-10-16 06:52:17 [RoutesResolver] AppController {/}: +48ms
app[web.1]: [Nest] 21 - 2018-10-16 06:52:17 [RouterExplorer] Mapped {/, GET} route +7ms
app[web.1]: [Nest] 21 - 2018-10-16 06:52:17 [NestApplication] Nest application successfully started +3ms
app[web.1]: Error waiting for process to terminate: No child processes
heroku[web.1]: Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch
heroku[web.1]: Stopping process with SIGKILL
heroku[web.1]: Process exited with status 22
heroku[web.1]: State changed from starting to crashed
heroku[web.1]: State changed from crashed to starting
Run Code Online (Sandbox Code Playgroud)
我的 package.json 文件在下面...
{
"name": "testy",
"version": "0.0.0",
"description": "description",
"author": "",
"license": "MIT",
"scripts": {
"format": "prettier --write \"src/**/*.ts\"",
"start": "ts-node -r tsconfig-paths/register src/main.ts",
"start:dev": "nodemon",
"start:debug": "nodemon --config nodemon-debug.json",
"prestart:prod": "rimraf dist && tsc",
"start:prod": "node dist/main.js",
"start:hmr": "node dist/server",
"lint": "tslint -p tsconfig.json -c tslint.json",
"test": "jest",
"test:watch": "jest --watch",
"test:cov": "jest --coverage",
"test:e2e": "jest --config ./test/jest-e2e.json",
"webpack": "webpack --config webpack.config.js"
},
"dependencies": {
"@nestjs/common": "^5.1.0",
"@nestjs/core": "^5.1.0",
"reflect-metadata": "^0.1.12",
"rxjs": "^6.2.2",
"typescript": "^3.0.1"
},
"devDependencies": {
"@nestjs/testing": "^5.1.0",
"@types/express": "^4.16.0",
"@types/jest": "^23.3.1",
"@types/node": "^10.7.1",
"@types/supertest": "^2.0.5",
"jest": "^23.5.0",
"nodemon": "^1.18.3",
"prettier": "^1.14.2",
"rimraf": "^2.6.2",
"supertest": "^3.1.0",
"ts-jest": "^23.1.3",
"ts-loader": "^4.4.2",
"ts-node": "^7.0.1",
"tsconfig-paths": "^3.5.0",
"tslint": "5.11.0",
"webpack": "^4.16.5",
"webpack-cli": "^3.1.0",
"webpack-node-externals": "^1.7.2"
},
"jest": {
"moduleFileExtensions": [
"js",
"json",
"ts"
],
"rootDir": "src",
"testRegex": ".spec.ts$",
"transform": {
"^.+\\.(t|j)s$": "ts-jest"
},
"coverageDirectory": "../coverage",
"testEnvironment": "node"
}
}
Run Code Online (Sandbox Code Playgroud)
如果有人在部署此堆栈方面有任何经验,很高兴收到您的来信
Heroku 默认为您分配一个端口,并将该端口添加到环境变量(env)中,因此您可以将端口设置为固定数字,您需要将主文件更改为:
import { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';
async function bootstrap() {
const app = await NestFactory.create(AppModule);
await app.listen(process.env.PORT || 3000);
}
bootstrap();
Run Code Online (Sandbox Code Playgroud)
小智 6
几个小时后...它已启动并运行!
1. package.json(注意:脚本、@nestjs版本、引擎)
{
"name": "nest",
"version": "0.0.0",
"description": "description",
"author": "",
"license": "MIT",
"scripts": {
"build": "tsc -p tsconfig.build.json",
"format": "prettier --write \"src/**/*.ts\"",
"start": "ts-node -r tsconfig-paths/register src/main.ts",
"start:dev": "nodemon",
"start:debug": "nodemon --config nodemon-debug.json",
"start:prod": "node dist/main.js",
"prestart:prod": "rimraf dist && npm run build",
"postinstall": "npm run prestart:prod",
"lint": "tslint -p tsconfig.json -c tslint.json",
"test": "jest",
"test:watch": "jest --watch",
"test:cov": "jest --coverage",
"test:debug": "node --inspect-brk -r tsconfig-paths/register -r ts-node/register node_modules/.bin/jest --runInBand",
"test:e2e": "jest --config ./test/jest-e2e.json",
"heroku-postbuild": "npm install --only=dev --no-shrinkwrap && npm run build"
},
"dependencies": {
"@nestjs/common": "6.7.2",
"@nestjs/core": "6.7.2",
"@nestjs/jwt": "0.2.0",
"@nestjs/mongoose": "5.2.2",
"@nestjs/passport": "5.1.0",
"@nestjs/platform-express": "6.7.2",
"bcrypt": "3.0.2",
"mongoose": "5.3.15",
"passport": "0.4.0",
"passport-jwt": "4.0.0",
"reflect-metadata": "0.1.12",
"rimraf": "2.6.2",
"rxjs": "6.2.2",
"typescript": "3.0.1"
},
"devDependencies": {
"@nestjs/testing": "5.1.0",
"@types/express": "4.16.0",
"@types/jest": "23.3.1",
"@types/node": "10.7.1",
"@types/supertest": "2.0.5",
"jest": "23.5.0",
"nodemon": "1.18.3",
"prettier": "1.14.2",
"supertest": "3.1.0",
"ts-jest": "23.1.3",
"ts-loader": "4.4.2",
"ts-node": "7.0.1",
"tsconfig-paths": "3.5.0",
"tslint": "5.11.0"
},
"jest": {
"moduleFileExtensions": [
"js",
"json",
"ts"
],
"rootDir": "src",
"testRegex": ".spec.ts$",
"transform": {
".+\\.(t|j)s$": "ts-jest"
},
"coverageDirectory": "../coverage",
"testEnvironment": "node"
},
"engines": {
"node": "8.9.4"
}
}
Run Code Online (Sandbox Code Playgroud)
2. Procfile(位置 - 与 package.json 相同) 是的,它是没有类型的文件。可以用记事本创建。
web: npm run start:prod
Run Code Online (Sandbox Code Playgroud)
3. 启用安装 devDependency(如果需要)
heroku config:set NPM_CONFIG_PRODUCTION=false
Run Code Online (Sandbox Code Playgroud)
我进行了以下更改来部署新生成的 Nest.js 应用程序:
main.ts- 改变了await app.listen(3000);
到
await app.listen(process.env.PORT || 3000);
新增Procfile内容:web: npm run start:prod
package.json- 添加了heroku-postbuild脚本,因此我的脚本如下所示:
"scripts": {
"build": "tsc -p tsconfig.build.json",
"format": "prettier --write \"src/**/*.ts\"",
"start": "ts-node -r tsconfig-paths/register src/main.ts",
"start:dev": "nodemon",
"start:debug": "nodemon --config nodemon-debug.json",
"prestart:prod": "rimraf dist && npm run build",
"start:prod": "node dist/main.js",
"lint": "tslint -p tsconfig.json -c tslint.json",
"test": "jest",
"test:watch": "jest --watch",
"test:cov": "jest --coverage",
"test:debug": "node --inspect-brk -r tsconfig-paths/register -r ts-node/register node_modules/.bin/jest --runInBand",
"test:e2e": "jest --config ./test/jest-e2e.json",
"heroku-postbuild": "npm install --only=dev --no-shrinkwrap && npm run build"
},
Run Code Online (Sandbox Code Playgroud)
目前运行于: https: //server-ts.herokuapp.com
似乎这里的所有解决方案都适用于以前版本的 Nest。
在我的例子中(NestJS v7.5.1)启动命令看起来像"nest start"
添加依赖项后一切正常"@nestjs/cli"。
| 归档时间: |
|
| 查看次数: |
8847 次 |
| 最近记录: |