当前位置: 首页 > 工具软件 > yaml.js > 使用案例 >

Nestjs系列配置config.yaml

李勇
2023-12-01

Nestjs设置dev和prod环境区分

第一步

npm i --save @nestjs/config // 默认使用的包为 dotenv
npm i js-yaml
npm i -D @types/js-yaml
npm i cross-env

第二步

  • src下建立config/configuration.ts 设置yaml引入文件需要
  • src下建立enum/config.enum.ts 方便管理枚举

第三步

 // config/configuration.ts 
 @@filename(configuration)
import { readFileSync } from 'fs';
import * as yaml from 'js-yaml';
import { join } from 'path';
import { merge } from 'lodash';
// 配置文件名称
const YAML_CONFIG_FILENAME = 'config.yaml';
const YAML_CONFIG_ENV = `config.${process.env.NODE_ENV || 'development'}.yaml`; // 这里名称与第五步对应起来
// path
const filePath = yaml.load(
  readFileSync(join(__dirname, '../../config', YAML_CONFIG_FILENAME), 'utf8'),
) as Record<string, any>;
const envPath = yaml.load(
  readFileSync(join(__dirname, '../../config', YAML_CONFIG_ENV), 'utf8'),
);
// 合并文件
const mergePath = merge(filePath, envPath);
export default () => {
  return mergePath;
};

第四步

// 在app.Module使用
 @@filename(app.Module)
import { Module } from '@nestjs/common';
import { ConfigModule } from '@nestjs/config';
import configuration from './config/configuration';
@Module({
  imports: [
    ConfigModule.forRoot({
      isGlobal: true,
      load: [configuration],
    }),
  ],
  controllers: [],
  providers: [],
})
export class AppModule {}

第五步

// 在根目录设置config/config.yaml
// 在根目录设置config/config.production 
// 在根目录设置config/config.development
@@filename(config.yaml) //config.yaml 文件内容
db:
  mysql: 'localhost:3000'
  mongoose: 'localhost:4000'
// end config.yaml
@@filename(config.development.yaml) //config.developmen.yaml 文件内容
db:
  NODE_ENV: 'development'
// end config.development.yaml
@@filename(config.production.yaml) //config.developmen.yaml 文件内容
db:
  NODE_ENV: 'production'
// end config.production.yaml

最后

// 配置package.json环境区分
@@filename(package.json)
	"scripts":{
	 	"start:dev": "cross-env NODE_ENV=development nest start --watch",
 	 	"start:prod": "cross-env NODE_ENV=production node dist/main",
	}	  

 类似资料: