任何人都知道通过capistrano以“滚动”方式重新启动杂种群集的好方法,例如,一次只有一个杂种.很高兴在那里有一些等待时间,让mongrel加载rails应用程序.
我做了一些搜索,并没有找到太多,所以在我自己潜入mongrel_cluster gem之前寻求帮助.
谢谢!
解决方法
我同意跷跷板方法而不是你正在寻求的滚动方法.问题是,在转换过程中,负载平衡可能会在不同版本的应用程序之间来回传递用户.
我们提出的解决方案(在找到SeeSaw之前,我们没有使用)是从负载平衡器中取出一半的杂物.关闭它们.更新它们.启动它们.将这些mongrels重新上线到负载均衡器中,然后关闭另一半.关闭下半场.更新下半场.启动它们.这大大减少了同时运行两个不同版本的应用程序的时间.
我写了一个Windows bat文件来做到这一点. (建议不要在Windows上部署,顺便说一句)
值得注意的是,进行数据库迁移可能会使整个方法变得有点危险.如果只有附加迁移,则可以在部署之前随时运行这些迁移.如果要删除列,则需要在部署后执行此操作.如果要重命名列,最好将其拆分为创建新列并将数据复制到迁移中以在部署之前运行,并使用单独的脚本在部署之后删除旧列.实际上,如果您没有特别努力组织它们,那么在生产数据库中使用常规迁移可能会很危险.所有这些都指向更频繁的交付,因此每次更新都是风险较低且不太复杂,但这是另一个响应的主题.