Heroku在heroku上找不到本地模块(Node.js)

时间:2012-04-10 02:30:15

标签: javascript node.js heroku express

我正在开发一个Node.js应用程序,并且正在使用一个公开我的Twitter API令牌/秘密的 config.js 文件。我这样做是因为我计划在完成应用程序之后开源应用程序,并且希望将这些应用程序保密(因此,将该文件放在我的.gitignore中。

无论如何,对于我的问题 - 我收到以下错误日志:

2012-04-09T22:41:12+00:00 app[web.1]: node.js:134
2012-04-09T22:41:12+00:00 app[web.1]:         ^
2012-04-09T22:41:12+00:00 app[web.1]:         throw e; // process.nextTick error, or 'error' event on first tick
2012-04-09T22:41:12+00:00 app[web.1]: Error: Cannot find module './config'
2012-04-09T22:41:12+00:00 app[web.1]:     at require (module.js:348:19)
2012-04-09T22:41:12+00:00 app[web.1]:     at Function._load (module.js:266:25)
2012-04-09T22:41:12+00:00 app[web.1]:     at Function._resolveFilename (module.js:320:11)
2012-04-09T22:41:12+00:00 app[web.1]:     at Object.<anonymous> (/app/app.js:6:19)
2012-04-09T22:41:12+00:00 app[web.1]:     at Module._compile (module.js:404:26)
2012-04-09T22:41:12+00:00 app[web.1]:     at Object..js (module.js:410:10)
2012-04-09T22:41:12+00:00 app[web.1]:     at Function._load (module.js:297:12)
2012-04-09T22:41:12+00:00 app[web.1]:     at EventEmitter._tickCallback (node.js:126:26)
2012-04-09T22:41:12+00:00 app[web.1]:     at Module.load (module.js:336:31)
2012-04-09T22:41:12+00:00 app[web.1]:     at Array.<anonymous> (module.js:423:10)
2012-04-09T22:41:13+00:00 heroku[web.1]: State changed from starting to crashed
2012-04-09T22:41:13+00:00 heroku[web.1]: Process exited with status 1

我的文件名是config.js,我正在我的应用中执行:var config = require('./config')。我没有将它列为package.json文件中的依赖项,因为它不在NPM中。

与foreman和Procfile一起在本地运行(就像heroku的文档说的那样)工作得很好。但是,当我需要一个本地文件时,我很困惑为什么它会给我一个错误。 config.js与我的app.js位于同一目录级别,因此要求它的路径是正确的。

编辑:以下是我在app.js中使用的代码部分:

var express     = require('express')
  , sys         = require('sys')
  , request     = require('request')
  , config      = require('./config')

谢谢 - 非常感谢任何帮助!

1 个答案:

答案 0 :(得分:15)

因为您将config.js文件放在.gitignore中,所以它没有被推送到Heroku服务器,就像您说的那样。对于您想要做的事情,您通常会使用Heroku's config vars设置环境变量,然后由应用程序读取:

$ heroku config:add TWITTER_TOKEN=<token> TWITTER_SECRET=<secret>

然后在app.js文件中,您可以使用以下命令访问这些环境变量:

var token = process.env['TWITTER_TOKEN'];
var secret = process.env['TWITTER_SECRET'];