ホームページ >ウェブフロントエンド >jsチュートリアル >Nest.js で環境変数とマルチ環境を構成する最良の方法

Nest.js で環境変数とマルチ環境を構成する最良の方法

WBOY
WBOYオリジナル
2024-08-10 06:40:36438ブラウズ

The Best way to configure environment variables and multi environments in Nest.js

Nest.js の気に入っているところは、これが強力で完全な Node.js フレームワークであり、構築のための独自の完全なソリューションを提供することです。バックエンド アプリケーション。

最初から

TypeScript サポートが組み込まれており、OOP (オブジェクト指向プログラミング)、FP (関数型プログラミング)、および FRP (Functional Reactive Programming)、公式 Web サイトにあるとおり。 最初からアーキテクチャも備えており、優れた構造化アーキテクチャ プロジェクトに取り組むのが好きな私のような人間にとっては素晴らしいことです。

ドキュメントだけでも非常に印象的で、

環境変数の設定方法を含むあらゆる側面を網羅していますが、私にとっては 複数の環境を設定する方法がよくわかりませんでした。
私がnode.jsとnestjsを初めて使用したためかもしれませんが、インターネットで記事を探すと、常にnestjsをネイティブに使用するのではなく、dotenvライブラリを直接使用する方法が示されていました。フード。

そして、ドキュメントの横にある記事を何時間も読んだ後、Nestjs にネイティブなソリューションを考え出し、それを共有したいと思いました。


まず

プロジェクトには 2 つの環境が必要であると仮定します

'dev'

'prod' そして、環境ごとに 2 つの環境変数が必要です: PORT
DATABASE_URL. 1-

PORT

DATABASE_URL を保存する 2 つの .env ファイルを作成し、ファイルに名前を付けます (.env.dev.env.prod.)

2-
PORT=3500

DATABASE_URL="file:./dev.db"`
NODE_ENV

という環境変数を作成します。ただし、今回は .env ファイルに保存するのではなく、dev と prod の起動スクリプトに挿入します。

NODE_ENV

の設定はプラットフォーム (Windows、Mac、または Linux) ごとに異なる場合があるため、プラットフォーム間で環境変数を設定できるようにするために、cross-div パッケージをインストールします。 npm を使用してインストール


または pnpm を使用する
$ npm install --save-dev cross-env


次に、クロス環境を使用するように package.json スクリプトを変更します。
$ pnpm install --save-dev cross-env


それでは、
"scripts": {
    "start:dev": "cross-env-shell NODE_ENV=dev nest start --watch",
    "start:prod": "cross-env-shell NODE_ENV=prod node dist/main",
}
を使用してアプリケーションを実行すると、


または
npm run start:dev 


pnpm run start:dev
NODE_ENV=dev

があり、それをアプリケーション全体で使用できます。 3- Nestjs が .env ファイルを読み取るためには、

ConfigModule

を使用して正しく設定する必要がありますが、その前にインストールする必要があります。 npm


pnpm
$ npm i --save @nestjs/config


4-
$ pnpm i --save @nestjs/config

ConfigModule

を使用します:

@Module({
  imports: [
    ConfigModule.forRoot({
      isGlobal: true,
      envFilePath: `.env.${process.env.NODE_ENV}`,
    }),
  ],
  controllers: [AppController],
  providers: [AppService],
})
export class AppModule {}

envFilePath: .env ファイルの別のパスを指定するために使用されます。  または、デフォルトの .env ファイルとは異なるファイルを読み取ります

.env.${process.env.NODE_ENV}

は、.env.dev および に変換されます。 コマンドを実行すると

npm run start:prod
.env.${process.env.NODE_ENV}

は、.env.prod. に変換されます。 5-

環境変数にアクセスする方法

環境変数にアクセスするには、ConfigModule
. を使用します。

main.ts

で使用できます

または別の場所で必要な場合は、注射を使用します。
async function bootstrap() {
  const app = await NestFactory.create(AppModule);

  const configService = app.get(ConfigService);
  const port = configService.get('PORT');

  await app.listen(port);
}
たとえば



@Injectable()
export class AppService {
  constructor(private configService: ConfigService) {}

  getHello(): string {
    return (
      this.configService.get<string>('DATABASE_URL')
    );
  }
}

以上がNest.js で環境変数とマルチ環境を構成する最良の方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。