Clojure 应用程序未在 Heroku 上启动; Aleph + RedisToGo 超时

标签 clojure heroku

我的 clojure noir 应用程序在本地 100% 正常运行,并且连接到 RedisToGo 没问题。

问题是当我部署到 Heroku (git push heroku master) 时,出现超时错误:

Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch

完整日志在这里:https://gist.github.com/1842439

当我删除这个 redis 连接代码时,它部署得很好:
(:use [aleph.redis :only (redis-client)])    
(def r (redis-client {:host redis-url :password redis-pass :port redis-port}))

奇怪的是,当我运行“heroku run lein run repl”并粘贴上面的aleph代码时,它可以很好地连接到redis并且我可以读/写数据。

所以它是关于 heroku 如何启动应用程序的,该应用程序会断开与 RedisToGo 的连接并使其超时。

最佳答案

在顶层做一些副作用是非常值得怀疑的 - 代码在编译和执行时都会执行,所以自动 uberjar Heroku 可能会失败,因为 redis 在编译时不可用,或者类似的东西。

相反,在 -main 之后初始化你的 redis 客户端已被调用,这将确保您处于生产环境中。您可以通过多种方式完成此操作,例如最初将其定义为 nil,然后执行 alter-var-root-main .我首选的解决方案可能是这样的:

(def r (delay (redis-client ...)))
(defn get-stuff []
  (let [client @r] ...))
(defn -main [& args]
  (get-stuff)
  ...)

现在,在有人取消引用客户端之前,不会执行要连接的代码,在应用程序启动并运行之前,他们不应该这样做。

关于Clojure 应用程序未在 Heroku 上启动; Aleph + RedisToGo 超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9316074/

相关文章:

ruby-on-rails - 如何在Heroku上删除Dyno?

Clojure:绑定(bind)与 with-redefs

clojure - 如何调试环形 session 存储?

heroku - Heroku:如何根据加载时间动态缩放测功机?

ruby-on-rails - 登录无法在 heroku 中使用

ruby-on-rails - Ruby on Rails PG::ConnectionBad

ruby-on-rails-3 - 部署到 heroku Assets 管道 Sprockets::fileNotFound

clojure - 使用 test.check 生成排序数据

clojure - 为什么我的 lein re-frame 模板中有 clj 和 cljs 文件夹?

clojure - 在 Clojure 中,Clojure 核心中其他最重要的功能是什么,必须掌握才能提高生产力?