Capistrano - 如何部署到多个云服务器

时间:2012-07-20 22:51:25

标签: deployment amazon-web-services capistrano cloud-hosting rackspace-cloud

我听说Capistrano支持部署到多个服务器,但我还没有找到一种实用的方法来设置它。当我说多个服务器时,我指的是在生产环境中运行相同应用程序的服务器。在任何时候,如果我正在使用它,我想部署到5台或10台服务器。

谢谢。

2 个答案:

答案 0 :(得分:7)

使用多个服务器是使用capistrano而不是手工操作的主要原因之一。

您的deploy.rb只需要定义应该在哪些服务器上执行哪些操作,这可以通过设置哪些服务器属于哪些角色来完成。您可以创建自己的角色,但内置的capistrano配方希望您定义3个角色:

  • app:运行应用程序代码的位置
  • web:网络前端
  • db:运行迁移的位置

这三个同义词并不罕见:如果你有一堆相同的服务器都运行apache + passenger,那么它们都是app和web服务器。其中一个需要被赋予db角色。

您可以在deploy.rb文件中定义角色。最简单的是这只是一个ip地址或主机名列表:

role :app, [192.168.1.1,192.168.1.2]

它也可以是一个块。例如,在部署到ec2时,您可能会插入一个api调用来检索要部署到的服务器列表。我通常通过为服务器分配标签来做到这一点,在这种情况下你可能有

role :app do
  ec2.instances.tagged('app').map(&:ip_address)
end

将该角色映射到带有app标签的ec2实例(capistrano缓存此信息,并且只执行一次块)

答案 1 :(得分:0)

我不得不在Rails 4中使用不同的语法。

role :app, %w{s01.app.com s02.app.com}
role :web, %w{s01.web.com s02.web.com}