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(模型),这感觉不对。
只需导出对象本身,而不是将其包装在函数中 - 节点模块在第一次加载后会被缓存,因此它不会再次运行逻辑。
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)
| 归档时间: |
|
| 查看次数: |
9941 次 |
| 最近记录: |