在 Nest.js 中定义 Node 环境

Nik*_*ola 4 javascript environment-variables node.js typescript nestjs

我正在设置 Nest.js 项目,我正在寻找定义ConfigService用于加载环境变量的Node 环境的有效解决方案:

import { Module } from '@nestjs/common';
import { ConfigService } from './config.service';

@Module({
    providers: [
        {
            provide: ConfigService,
            useValue: new ConfigService(`environments/${process.env.NODE_ENV}.env`)
        }
    ],
    exports: [ConfigService]
})
export class ConfigModule {}
Run Code Online (Sandbox Code Playgroud)

现在我直接在 npm 脚本中定义它(例如"start:dev": "NODE_ENV=development nodemon"),但我想知道是否有更好的方法来处理不同的环境而不是将它附加到每个脚本中?

Kim*_*ern 6

发展

如果应该始终development将其设置为系统变量,请参阅下面的生产/暂存。如果你想在开发过程中运行不同的环境,附加你的 npm run 脚本是一种方法。此外,您可以使用cross-env来确保您的脚本在不同平台上工作:

"start": "cross-env NODE_ENV=development ts-node -r tsconfig-paths/register src/main.ts",
Run Code Online (Sandbox Code Playgroud)

测试

如果你想在不同的环境中运行你的集成测试,你可以在你的jest-e2e.json

"globals": {
  "NODE_ENV": "test"
}
Run Code Online (Sandbox Code Playgroud)

也可以在测试代码中为一项特定测试设置(或更改)您的环境:

let previousNodeEnv;
beforeAll(() => {
  previousNodeEnv = process.env.NODE_ENV;
  process.env.NODE_ENV = 'test';
});

afterAll(() => process.env.NODE_ENV = previousNodeEnv);
Run Code Online (Sandbox Code Playgroud)

制作/分期

在登台或生产系统上,我建议将其设置为普通系统变量,请参阅此线程


小智 5

如果没有跨环境,您可以使用:

"start:local": "NODE_ENV=test ts-node -r tsconfig-paths/register src/main.ts "
Run Code Online (Sandbox Code Playgroud)