目前我在代码中使用此模式:
module.exports.getMySQL = () => {
return process.env.CLEARDB_DATABASE_URL || config.get('MySQL').connection;
}
但是,node-config声称能够将这些变量集成到文件中。
https://github.com/lorenwest/node-config/wiki/Environment-Variables#custom-environment-variables
{
"Customer": {
"dbConfig": {
"host": "PROD_SERVER"
},
"credit": {
"initialDays": "CR_ID"
},
// Environment variables containing multiple configs
// New as of config@1.14.0
"settings": {
"adminAccounts": {
"__name": "ADMIN_ACCS",
"__format": "json"
}
}
}
}
究竟是什么"PROD_SERVER"
如果我用"process.env.SOME_ENVIRONMENT_VARIABLE"
替换它,它就不起作用,我的服务器崩溃了。
我确实使用Heroku GUI验证"process.env.SOME_ENVIRONMENT_VARIABLE"
存在。
答案 0 :(得分:0)
PROD_SERVER可以是您尝试连接的数据库服务器的名称,如果您需要从Heroku配置中读取它,则需要在heroku中设置配置。
假设您使用名称设置环境变量 heroku中的“DATABASE_URL” 您可以在代码中以process.env.DATABASE_URL。
访问它您的Heroku应用的环境变量将在您的应用的设置标签中提供。 在“配置变量”下
当您使用process.env.SOME_ENVIRONMENT_VARIABLE时,您的服务器崩溃,因为未在配置中设置该值,您可以查看Heroku应用程序的控制台以获取更多详细信息。
答案 1 :(得分:0)
我是node-config
的维护者之一。
PROD_SERVER
是环境变量名称的示例。
您可以将SOME_ENVIRONMENT_VARIABLE
放在custom-environment-variables.json
中,但不要将process.env.SOME_ENVIRONMENT_VARIABLE
放在JSON文件中。
从您提供的示例custom-environment-variables.json
文件中,您可以使用config.get('Customer.dbConfig.host')
,这将引用您在PROD_SERVER
环境变量中设置的值。