node.js - 在heroku 上启动geddy 失败并出现错误R11(错误绑定(bind))。部署有什么问题?我缺少什么?

标签 node.js heroku geddy

我正在尝试在 Heroku 中进行新的部署,似乎无法让 geddy 顺利运行。

我不断收到此错误

错误 R11(错误绑定(bind))-> 进程绑定(bind)到端口 5768,应为 41113(请参阅环境变量 PORT)

配置文件

web: geddy -p 5768

package.json

{
  "name": "oskalisti",
  "version": "0.0.1",
  "dependencies": {
    "geddy": "0.3.20",
    "jake": "0.2.31"
  }
}

完整日志:

2012-04-13T17:47:26+00:00 app[web.1]: [Fri, 13 Apr 2012 17:47:26 GMT] INFO Server starting with config: {
2012-04-13T17:47:26+00:00 app[web.1]:   "environment": "development",
2012-04-13T17:47:26+00:00 app[web.1]:   "workers": 1,
2012-04-13T17:47:26+00:00 app[web.1]:   "port": "5768",
2012-04-13T17:47:26+00:00 app[web.1]:   "debug": true,
2012-04-13T17:47:26+00:00 app[web.1]:   "rotateWorkers": false,
2012-04-13T17:47:26+00:00 app[web.1]:   "rotationWindow": 7200000,
2012-04-13T17:47:26+00:00 app[web.1]:   "rotationTimeout": 300000,
2012-04-13T17:47:26+00:00 app[web.1]:   "logDir": "/app/log",
2012-04-13T17:47:26+00:00 app[web.1]:   "gracefulShutdownTimeout": 30000,
2012-04-13T17:47:26+00:00 app[web.1]:   "heartbeatInterval": 5000,
2012-04-13T17:47:26+00:00 app[web.1]:   "heartbeatWindow": 20000,
2012-04-13T17:47:26+00:00 app[web.1]:   "staticFilePath": "/app/public",
2012-04-13T17:47:26+00:00 app[web.1]:     "store": "memory",
2012-04-13T17:47:26+00:00 app[web.1]:     "key": "sid",
2012-04-13T17:47:26+00:00 app[web.1]:   "sessions": {
2012-04-13T17:47:26+00:00 app[web.1]:     "expiry": 1209600
2012-04-13T17:47:26+00:00 app[web.1]:   "cookieSessionKey": "sdata",
2012-04-13T17:47:26+00:00 app[web.1]:   "metrics": null,
2012-04-13T17:47:26+00:00 app[web.1]:   },
2012-04-13T17:47:26+00:00 app[web.1]:   "i18n": {
2012-04-13T17:47:26+00:00 app[web.1]:     "defaultLocale": "en-us",
2012-04-13T17:47:26+00:00 app[web.1]:     "loadPaths": [
2012-04-13T17:47:26+00:00 app[web.1]:       "/app/config/locales"
2012-04-13T17:47:26+00:00 app[web.1]:     ]
2012-04-13T17:47:26+00:00 app[web.1]:   },
2012-04-13T17:47:26+00:00 app[web.1]:   "ssl": null,
2012-04-13T17:47:26+00:00 app[web.1]:   "model": {
2012-04-13T17:47:26+00:00 app[web.1]:     "useTimestamps": false,
2012-04-13T17:47:26+00:00 app[web.1]:     "forceCamel": true
2012-04-13T17:47:26+00:00 app[web.1]:   },
2012-04-13T17:47:26+00:00 app[web.1]:   "detailedErrors": true,
2012-04-13T17:47:26+00:00 app[web.1]:   "hostname": null
2012-04-13T17:47:26+00:00 app[web.1]: }
2012-04-13T17:47:26+00:00 app[web.1]: [Fri, 13 Apr 2012 17:47:26 GMT] INFO Creating 1 worker process.
2012-04-13T17:47:26+00:00 app[web.1]: [Fri, 13 Apr 2012 17:47:26 GMT] INFO Server worker running in development on port 5768 with a PID of: 6
2012-04-13T17:47:26+00:00 app[web.1]: [Fri, 13 Apr 2012 17:47:26 GMT] DEBUG LOGGING STARTED ============================================
2012-04-13T17:47:26+00:00 app[web.1]: [Fri, 13 Apr 2012 17:47:26 GMT] DEBUG ============================================================
2012-04-13T17:47:27+00:00 heroku[web.1]: Error R11 (Bad bind) -> Process bound to port 5768, should be 22421 (see environment variable PORT)

任何帮助将不胜感激。谢谢。

最佳答案

好的,找到问题了,傻瓜。

在 Procfile 上我不应该使用端口号,heroku 会使用 $PORT 变量为我提供该端口。

所以我让 Procfile 看起来像这样:

web: geddy -p $PORT

这很有效。我还修改了 production.js 环境配置文件以也使用 heroku 端口,如下所示:

var config = {
  detailedErrors: false
, hostname: null
, port: process.env.PORT
, sessions: {
    store: 'memory'
  , key: 'sid'
  , expiry: 14 * 24 * 60 * 60
  }
};

module.exports = config;

请注意其中的port: process.env.PORT 行。

然后,如果您以这种方式更改文件,则可以像这样启动geddy,而不是在 Procfile 文件上使用 $PORT 变量:

web: geddy -e production

只有更好的实践,这样您的生产配置才能加载,并且您可以真正支持不同的环境。

关于node.js - 在heroku 上启动geddy 失败并出现错误R11(错误绑定(bind))。部署有什么问题?我缺少什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10145960/

相关文章:

windows - 适用于 Windows 的 NPM 包 'bin' 脚本

node.js - 如何使用 sails-mongodb 获取 'and' 查询

ruby-on-rails - 记录到 Redis for Rails 应用程序

c++ - Node.js C++ Addon - 设置数组的特定索引

jquery - 模拟 POST 请求

wordpress - 在 Heroku 上部署 WordPress?

python-3.x - ImportError : No module named 'decouple' while deploying on Heroku

node.js - Geddy CLI 在 SSH 丢弃时关闭

javascript - 为选项添加一个值

node.js - 将Post数据传递到geddy nodejs中的application.html.ejs