使用Capistrano滚动部署Java / Tomcat应用程序

时间:2014-06-04 23:26:13

标签: java tomcat deployment capistrano

我正在使用Capistrano 2.15.5将Java Web应用程序部署到Tomcat应用程序服务器。目前,我们与这个版本的Capistrano捆绑并致力于我们无法升级到v3。部署任务将调用其他任务以在角色中的所有服务器上并行执行。这按预期工作,并且一直运作良好。

现在,我们需要在一台服务器上执行任务时实施 Rolling Deployment 。因此,根据下面的代码,我们首先在shutdown_tomcat, download_bits, deploy_bits, start_tomcat上执行prdapp01,然后在prdapp02执行...依此类推......这样,群集中只有一台服务器在任何给定时间都处于脱机状态,从而最大化我们的正常运行时间。

使用Capistrano实施此滚动部署策略的最佳方法是什么?

这是我目前的Capistrano脚本的配对版本:

task :production do
  role :app,   "deployuser@prdapp01", "deployuser@prdapp02", "deployuser@prdapp03"
  # ...
end

task :deploy do
  shutdown_tomcat
  download_bits
  deploy_bits
  start_tomcat
end

task :shutdown_tomcat, :roles => :app do
  run "sudo /sbin/service tomcat stop || exit 1;"
end

task :download_bits, :roles => :app do
  run <<-EOS
    [ -f /tmp/app_download ] && rm -rf /tmp/app_download;
    mkdir -p /tmp/app_download;
    cd /tmp/app_download;
    wget -q https://internal.server/path/to/application.war || exit 1;
  EOS
end

task :deploy_bits, :roles => :app do
  run <<-EOS
    cd /tmp/app_download;
    unzip -q -o /tmp/app_download/application.war -d /usr/local/tomcat/webapps/ || exit 1;
    exit 0;
  EOS
end

task :start_tomcat, :roles => :app do
  run "sudo /sbin/service tomcat start || exit 1;"
end

1 个答案:

答案 0 :(得分:2)

我相信我想出了一个合理的 Rolling Deployment 解决方案 我上面描述的策略。首先,我向Capistrano传递一个论据 它是我想要执行的部署类型:完整滚动。然后我跟着 这个过程:

  1. 将服务器列表从相应的角色捕获到另一个列表中。
  2. 迭代新列表。
  3. 将原始角色重置为当前服务器的值。
  4. 仅将该所有任务应用于该服务器
  5. 皮革,漂洗,重复......
  6. 以下是deploy任务的相关更改:

    task :deploy do
      deploy_type = fetch(:deploytype).downcase
      case deploy_type
        when 'full' then
          shutdown_tomcat
          download_bits
          deploy_bits
          start_tomcat
        when 'rolling' then
          server_list = roles[:app].servers    # get the original servers
          server_list.each do |current_server| # apply other tasks in series
            roles[:app].servers = []           # reset original server list
            role :app, "#{current_server}"     # otherwise you'll append to it
            shutdown_tomcat
            download_bits
            deploy_bits
            start_tomcat
          end                                  # each loop
        else
          puts 'Invalid deployment type'
          exit
      end                                      # case deploy_type
    end                                        # task :deploy
    

    然后您可以使用以下命令调用它:

    $ cap -f deploy.cap -s deploytype=rolling production deploy
    

    感谢您的反馈!