源:
http://blog.csdn.net/largetalk/article/details/6743090
setp 1:
gem install capistrano
gem install capistrano-ext
setp 2: 在项目根目录执行
capify .
这将在根目录创建Capfile 和 config目录下创建deploy.rb 文件
setp 3: 编辑deploy.rb
require 'bundler/capistrano' #添加之后部署时会调用bundle install, 如果不需要就可以注释掉
require "capistrano/ext/multistage" #多stage部署所需
set :stages, %w(development production)
set :default_stage, "development"
set :application, "crm_app_end" #应用名称
set :repository, "https://chang.abc.com/svn/engineering/vwaccount/mydeploy/trunk"
set :keep_releases, 5 #只保留5个备份
set :deploy_to, "/var/www/#{application}" #部署到远程机器的路径
set :user, "user1" #登录部署机器的用户名
set :password, "user1" #登录部署机器的密码, 如果不设部署时需要输入密码
default_run_options[:pty] = true #pty: 伪登录设备
#default_run_options[:shell] = false #Disable sh wrapping
set :use_sudo, true #执行的命令中含有sudo, 如果设为false, 用户所有操作都有权限
set :runner, "user2" #以user2用户启动服务
set :svn_username, "xxxx"
set :scm, :subversion #
# Or: `accurev`, `bzr`, `cvs`, `darcs`, `git`, `mercurial`, `perforce`, `subversion` or `none`
#set :deploy_via, :copy #如果SCM设为空, 也可通过直接copy本地repo部署
#set :domain, "crm.abc.com" #custom define
role :web, "192.168.0.13", "192.168.0.117" # Your HTTP server, Apache/etc
role :app, "192.168.0.13", "192.168.0.117" # This may be the same as your `Web` server
role :db, "192.168.0.13", :primary => true # This is where Rails migrations will run
#role :db, "your slave db-server here"
#
namespace :deploy do
desc "remove and destory this app"
task :destory, :roles => :app do
run "cd #{deploy_to}/../ && #{try_sudo} mv #{application} /tmp/#{application}_#{Time.now.strftime('%Y%d%m%H%M%S')}" #try_sudo 以sudo权限执行命令
end
after "deploy:update", "deploy:shared:setup" #after, before 表示在特定操作之后或之前执行其他任务
namespace :shared do
desc "setup shared folder symblink"
task :setup do
run "cd #{deploy_to}/current; rm -rf shared; ln -s #{shared_path} ."
end
end
after "deploy:setup", "deploy:setup_chown"
desc "change owner from root to user1"
task :setup_chown do
run "cd #{deploy_to}/../ && #{try_sudo} chown -R #{user}:#{user} #{application}"
end
task :start do
run "cd #{deploy_to}/current && ./crmd.sh start"
#try_sudo "cd #{deploy_to}/current && ./restart.sh"
end
task :stop do
run "cd #{deploy_to}/current && ./crmd.sh stop"
end
task :restart do
run "cd #{deploy_to}/current && ./crmd.sh restart"
end
end
setup 4: 在项目根目录执行
cap deploy:setup #建立部署路径
cap deploy:update #部署
cap deploy:start #启动服务
cap deploy:stop #停止服务
cap deploy:restart #重启服务
setup 5: 如果有多个stage要部署,则在config下创建deploy文件夹, 在该文件夹下有各stages文件, 文件名和 set :stages, %w(development production) 对应, 如development.rb production.rb,在各文件中设置相应变量即可, 然后可用 cap production deploy:... 来执行对应production的操作
其实capistrano最终都是转变成shell命令来完成任务的, 所以纯粹用shell脚本也可以完成相应功能, 但相对于晦涩的shell命令, capistrano明显更好懂, 并且它有很多默认操作非常好用, 比如setup, update, 如果自己用shell来实现非常麻烦, capistrano允许在脚本中嵌入shell, 比如上面的start, restart等, 这非常方便, 很多capistrano做不到的就可以用shell去搞定了
这事最近又有了新进展,我在一个django项目中用capistrano来发布,虽然python下也有一个叫fabric的东西,但那个还不熟,先用这个,有时间学习一下fabric再说
require 'bundler/capistrano' #添加之后部署时会调用bundle install, 如果不需要就可以注释掉
#require "capistrano/ext/multistage" #多stage部署所需
set :application, "app" #应用名称
set :scm, :subversion
set :repository, "svn://0.0.0.0/trunk/src"
set :keep_releases, 5 #只保留5个备份
set :deploy_to, "/var/www/#{application}" #部署到远程机器的路径
set :user, "xxx" #登录部署机器的用户名
set :password, "xxxxx" #登录部署机器的密码, 如果不设部署时需要输入密码
default_run_options[:pty] = true #pty: 伪登录设备
#default_run_options[:shell] = false #Disable sh wrapping
#set :use_sudo, true #执行的命令中含有sudo, 如果设为false, 用户所有操作都有权限
set :runner, "xxxx" #以用户启动服务
#set :deploy_via, :copy #如果SCM设为空, 也可通过直接copy本地repo部署
role :web, "172.16.120.222"#, "192.168.0.117" # Your HTTP server, Apache/etc
role :app, "172.16.120.222"#, "192.168.0.117" # This may be the same as your `Web` server
role :db, "172.16.120.222", :primary => true # This is where Rails migrations will run
#role :db, "your slave db-server here"
#
namespace :deploy do
desc "remove and destory this app"
task :destory, :roles => :app do
run "cd #{deploy_to}/../ && #{try_sudo} mv #{application} /tmp/#{application}_#{Time.now.strftime('%Y%d%m%H%M%S')}" #try_sudo 以sudo权限执行命令
end
# after "deploy:setup", "deploy:setting_link"
# desc "symlink for settings.py"
# task :setting_link do
# run "cd #{deploy_to}; #{try_sudo} touch current; #{try_sudo} ln -s current releases/#{application}"
# end
after "deploy:update", "deploy:shared:setup" #after, before 表示在特定操作之后或之前执行其他任务
namespace :shared do
desc "setup shared folder symblink"
task :setup do
run "cd #{deploy_to}/current; ln -s #{shared_path} x"
run "cd #{deploy_to}/current; rm -rf log; ln -s #{shared_path}/log log"
run "cd #{deploy_to}/releases; rm -f #{application} && __realversion__=`realpath ../current` && ln -s $__realversion__ #{application}"
end
end
after "deploy:setup", "deploy:setup_chown"
desc "change owner from root to user1"
task :setup_chown do
run "cd #{deploy_to}/../ && #{try_sudo} chown -R #{user}:#{user} #{application}"
end
task :default do
transaction do
update_code
symlink
end
end
task :update_code, :except => { :no_release => true } do
on_rollback { run "rm -rf #{release_path}; true" }
strategy.deploy!
end
before "deploy:rollback", "deploy:clean_adaptive"
task :clean_adaptive do
run "cd #{deploy_to}/releases; rm -f #{application}"
end
after "deploy:rollback", "deploy:rollback_set"
task :rollback_set do
run "cd #{deploy_to}/releases; rm -f #{application} && __realversion__=`realpath ../current` && ln -s $__realversion__ #{application}"
end
task :start do
run "cd #{deploy_to}/current && ./adaptive_pool.sh start"
run "cd #{deploy_to}/current && ./adaptive_exam.sh start"
end
task :stop do
run "cd #{deploy_to}/current && ./adaptive_pool.sh stop"
run "cd #{deploy_to}/current && ./adaptive_exam.sh stop"
end
task :restart do
run "cd #{deploy_to}/current && ./adaptive_pool.sh restart"
run "cd #{deploy_to}/current && ./adaptive_exam.sh restart"
end
end