ruby-on-rails – Heroku的零停机时间

有可能在Heroku上使用雪茄上的Unicorn做一些像 the Github zero downtime deploy这样的东西吗?

我不完全确定重启在Heroku上的工作以及对重新启动进程的控制,但是我喜欢零停机部署的可能性,直到现在,从what I’ve read开始,这是不可能的

有一些事情需要这个工作.

>首先,我们需要向后兼容的迁移.我离开了我们的团队去弄清楚.
>其次,我们希望在推送后立即迁移数据库,但是在重新启动之前(假设我们的迁移完全向后兼容,这不应该影响任何东西)
>第三,我们想指示Unicorn启动一个新的主程序,并分配一些工作人员,然后交换PID并优雅地关闭旧的进程/工作程序

我已经浏览了这些文档,但是我找不到任何可以在Heroku上显示内容.有什么想法吗?

解决方法

我无法解决迁移问题,但是关于重新启动进程并避免等待时间的部分:

一个称为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/

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...