1、nestjs中的config模块
在 NestJS 中,根据不同环境获取不同的 .env
配置文件可以通过使用 @nestjs/config
包来实现,这个包基于 dotenv
并提供了额外的功能,使得加载环境变量更加灵活和方便。以下是如何根据不同环境加载不同 .env
文件的步骤:
-
安装
@nestjs/config
:首先,确保你已经安装了@nestjs/config
包。npm install --save @nestjs/config
-
配置
ConfigModule
:在你的根模块(通常是AppModule
)中,使用ConfigModule.forRoot
方法来配置ConfigModule
。import { Module } from '@nestjs/common'; import { ConfigModule } from '@nestjs/config'; import * as path from 'path'; @Module({ imports: [ ConfigModule.forRoot({ // 这里可以根据环境变量来决定加载哪个 .env 文件 envFilePath: process.env.NODE_ENV === 'production' ? '.env.prod' : '.env',// 如果设置为 true,则会忽略 .env 文件,只使用 process.env 中的环境变量 ignoreEnvFile: process.env.NODE_ENV === 'production', // 默认为 false,表示 ConfigService 是全局的 isGlobal: true, }), // ... 其他模块 ], // ... 其他代码 }) export class AppModule {}
-
使用环境变量:在上述代码中,
envFilePath
的值会根据NODE_ENV
环境变量的值来决定加载哪个.env
文件。如果NODE_ENV
设置为production
,则加载.env.prod
文件;否则,默认加载.env
文件。 -
使用
ConfigService
:配置好ConfigModule
后,你可以在应用程序的任何地方使用ConfigService
来获取环境变量的值。import { ConfigService } from '@nestjs/config'; import { Injectable } from '@nestjs/common'; @Injectable() export class MyService { constructor(private configService: ConfigService) { const myConfigValue = this.configService.get<string>('MY_CONFIG_KEY'); // 使用 myConfigValue } }
-
启动应用:在启动应用时,通过命令行设置
NODE_ENV
环境变量,以便加载正确的.env
文件。NODE_ENV=production npm run start
或者,如果你使用
cross-env
包来跨平台设置环境变量:npx cross-env NODE_ENV=production npm run start
确保在
package.json
中的scripts
部分配置了相应的启动脚本。
2、config文件加cross-env
首先安装cross-env
npm i cross-env
然后添加配置文件,config/index.ts:
const ENV = process.env.NODE_ENV
console.log('env ======== ', ENV)
const isDev = ENV === 'dev'
export default {
database_host: isDev ? '' : '',
database_pwd: isDev ? '' : '',
database_port: isDev ? 3306 : 0,
database_sync: isDev ? true : false,
loginSecretKey: '',
loginExpireTime: 60 * 60 * 24 * 7 * 1000, //单位毫秒
aesKey: '',
aesIv: '',
pwdSaltOrRounds: 10
}
有多个环境可以自己加个判断
然后在package.json的运行语句里面加上
"build": "cross-env NODE_ENV=prod nest build NODE_ENV=prod",
"build:test": "cross-env NODE_ENV=test nest build NODE_ENV=test",
"start:dev": "cross-env NODE_ENV=dev nest start --watch",