有可能在Heroku上使用雪茄上的Unicorn做一些像
the Github zero downtime deploy这样的东西吗?
我不完全确定重启在Heroku上的工作以及对重新启动进程的控制,但是我喜欢零停机部署的可能性,直到现在,从what I’ve read开始,这是不可能的
有一些事情需要这个工作.
>首先,我们需要向后兼容的迁移.我离开了我们的团队去弄清楚.
>其次,我们希望在推送后立即迁移数据库,但是在重新启动之前(假设我们的迁移完全向后兼容,这不应该影响任何东西)
>第三,我们想指示Unicorn启动一个新的主程序,并分配一些工作人员,然后交换PID并优雅地关闭旧的进程/工作程序
解决方法
我无法解决迁移问题,但是关于重新启动进程并避免等待时间的部分:
有一个称为preboot的英雄的beta功能.部署之后,首先启动新的dynos,并等待一段时间才能切换流量并杀死旧的数据:
https://devcenter.heroku.com/articles/labs-preboot/
我还写了一篇博客文章,使用此功能对我的应用程序的性能进行了一些测量:
http://ylan.segal-family.com/blog/2012/08/27/deploy-to-heroku-with-near-zero-downtime/