我的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的连接并超时。
发布于 2012-02-17 03:03:42
在顶层做一些副作用的事情是非常可疑的-代码在编译和执行时都会被执行,所以很可能自动的uberjar Heroku会失败,因为redis在编译时不可用,或者类似的东西。
相反,在调用-main之后初始化您的redis客户端,这将确保您处于生产环境中。您可以通过多种方式来实现这一点,例如,最初将其定义为nil,然后在-main中执行alter-var-root。我首选的解决方案可能是这样的:
(def r (delay (redis-client ...)))
(defn get-stuff []
(let [client @r] ...))
(defn -main [& args]
(get-stuff)
...)现在,要连接的代码不会执行,直到有人解除客户端,这是他们永远不应该这样做,直到应用程序启动并运行。
https://stackoverflow.com/questions/9316074
复制相似问题