在 Node.JS 中使用配置文件的最佳方法

And*_*ett 2 javascript mysql node.js node-mysql

我有一个 Node.JS 应用程序的配置文件(如下简化)

module.exports = function(){
  var settings = {
    port: '8088'
  }; 
  settings.mysql = {
    host : 'localhost',
    database : 'test'
  };
  // Override default settings
  switch(process.env.NODE_ENV){
    case 'production':
      settings.port = 8082;
    break;
    case 'staging':
      settings.port = 8083;
    break;     
  }
  return settings;
};
Run Code Online (Sandbox Code Playgroud)

当我启动 Express.js 应用程序时,我需要此文件进行一些基本设置:

var Config = require('./config'),  settings = new Config();
var port = process.env.PORT || settings.port;    // set our port
Run Code Online (Sandbox Code Playgroud)

稍后我还需要在 DAO 中(在我的模型中)使用此文件中的 MySQL 设置。此时我调用配置文件(它将再次运行它)

var Config = require('../config'), settings = new Config();
var mysql = require('mysql');
var pool = mysql.createPool(settings.mysql);
Run Code Online (Sandbox Code Playgroud)

显然,每次我“要求”文件运行时,这看起来都很懒惰/效率低下。我应该将返回的“设置”变量存储在我的 DAO 可以看到的全局变量中,还是应该通过引用传递它?

我曾经一度考虑过将其制作为中间件并将其添加到请求中,但随后我需要我的路线(控制器)将其全部传递给 DAO(模型),这感觉不对。

Joe*_*lay 5

只需导出对象本身,而不是将其包装在函数中 - 节点模块在第一次加载后会被缓存,因此它不会再次运行逻辑。

var settings = {
  port: '8088'
}; 

settings.mysql = {
  host : 'localhost',
  database : 'test'
};

// Override default settings
switch(process.env.NODE_ENV){
  case 'production':
    settings.port = 8082;
  break;
  case 'staging':
    settings.port = 8083;
  break;     
}

module.exports = settings;
Run Code Online (Sandbox Code Playgroud)