Не удается запустить производственную сборку - PullRequest
1 голос
/ 09 апреля 2019

Я занимаюсь разработкой API с использованием nestjs и TypeORM, связанных с PostgreSQL. NestJS использует файл ormconfig.json для подключения к базе данных.

{
  "type": "postgres",
  "host": "localhost",
  "port": 5432,
  "username": "xyz",
  "password": "xyz",
  "database": "xyz",
  "entities": ["src/**/**.entity{.ts,.js}"],
  "synchronize": true
}

В режиме разработки npm run start:dev все работает нормально, API отвечает, правильно связан с базой данных. Но когда я пытаюсь запустить производственную сборку: npm run prestart:prod, а затем npm run start:prod что-то ломается, и программа не может подключиться к базе данных, что вызывает ошибку:

[Nest] 12444   - 2019-04-09 22:19   [NestFactory] Starting Nest application...
[Nest] 12444   - 2019-04-09 22:19   [InstanceLoader] TypeOrmModule dependencies initialized +85ms
[Nest] 12444   - 2019-04-09 22:19   [InstanceLoader] AppModule dependencies initialized +3ms
[Nest] 12444   - 2019-04-09 22:19   [TypeOrmModule] Unable to connect to the database. Retrying (1)... +111ms
C:\_code\sensorhub\packages\api-nestjs\src\installations\models\installation.entity.ts:1
(function (exports, require, module, __filename, __dirname) { import { Entity, PrimaryGeneratedColumn, Column } from 'typeorm';
                                                                     ^

SyntaxError: Unexpected token {
    at new Script (vm.js:79:7)
    at createScript (vm.js:251:10)
    at Object.runInThisContext (vm.js:303:10)
    at Module._compile (internal/modules/cjs/loader.js:657:28)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:700:10)
    at Module.load (internal/modules/cjs/loader.js:599:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:538:12)
    at Function.Module._load (internal/modules/cjs/loader.js:530:3)
    at Module.require (internal/modules/cjs/loader.js:637:17)
    at require (internal/modules/cjs/helpers.js:22:18)
[Nest] 12444   - 2019-04-09 22:19   [TypeOrmModule] Unable to connect to the database. Retrying (2)... +3130ms

installation.entity.ts

import { Entity, PrimaryGeneratedColumn, Column } from 'typeorm';

@Entity()
export class InstallationEntity {
  @PrimaryGeneratedColumn()
  id: number;

  @Column({ length: 500 })
  name: string;

  @Column('text')
  description: string;
}

Я думаю, что сам код правильный, но что-то не так с правильной конфигурацией.

nestjs ver.6.0.0

1 Ответ

1 голос
/ 12 апреля 2019

попробуйте это: https://github.com/nestjs/nest/issues/184 с использованием динамического ormconfig.js (вместо .json)

...