我正在使用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
答案 0 :(得分:2)
我相信我想出了一个合理的 Rolling Deployment 解决方案 我上面描述的策略。首先,我向Capistrano传递一个论据 它是我想要执行的部署类型:完整或滚动。然后我跟着 这个过程:
以下是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
感谢您的反馈!