使用Capistrano向EC2部署Django代码

Capistrano是一种在多台服务器上运行脚本的开源工具,它能自动完成多台服务器上新版本代码的同步更新,包括数据库的改变,主要用于部署web应用。Capistrano最初由Jamis Buck用Ruby开发,并用RubyGems部署渠道部署。现在Capistrano不仅限于应用Ruby on Rails的 web应用框架,而且可以用于部署用其他框架的web应用程序,比如用Django开发的。  

  • Capistrano的安装
  • sudo gem install capistrano
  • 为项目使用Capistrano
  • #进入项目的根目录
    $ cd sample
    
    #capification
    $ capify .
    
    #这个命令执行完会在当前目录下产生两个文件。
    #Capfile:这个是capistrano需要的一个主文件,就像make命令自动加载Makefile一样,capistrano默认自动寻找和加载该文件,该文件主要用于加载config/deploy.rb,一般不用修改该文件
    #
    $ cat Capfile
    load 'deploy'
    # Uncomment if you are using Rails' asset pipeline
        # load 'deploy/assets'
    Dir['vendor/gems/*/recipes/*.rb','vendor/plugins/*/recipes/*.rb'].each { |plugin| load(plugin) }
    load 'config/deploy' # remove this line to skip loading any of the default tasks
    
    #config/deploy.rb:这个是主要的配置文件,所有的跟部署相关的信息都在该文件里进行定制

 

接下来就是配置deploy.rb文件。(目前capistrano只支持SSH访问远端服务器,不支持Telnet和FTP方式)

* 这里使用了multistage功能,配置development,staging和production三个场景。各个场景的具体设置放在config/deploy/下面的development.rb, staging.rb, production.rb里面

* deploy.rb

# multi stage
set :stages, %w(development staging production)
set :default_stage, "development"
require "capistrano/ext/multistage"

* deploy.rb

set :application, "xxxxxx"

set :scm, :git # 需要事先确认部署服务器上安装了git
set :repository, "git@github.com:xxx.git"
set :git_enable_submodules, 1
set :user, "webapp" # 需要事先确认该用户对后面定义的[deploy_to]具有读写的权利
set :use_sudo, false

default_run_options[:pty] = true #访问git时候确认fingerprint和password的时候必须设置
set :deploy_via, :remote_cache

after :deploy, "deploy:cleanup"

* production.rb

set :deploy_to, "/var/webapps/#{application}" # 需要确认服务器上有该目录
set :settings_name, "production"

ssh_options[:forward_agent] = true
ssh_options[:port] = 22

set :copy_exclude, ['.git']

role :app, "xxxx", :primary => true
role :app, "xxxx"
role :web, "xxx"
role :db,  "xxx", :primary => true
role :db,  "xxx"

namespace :deploy do
  task :finalize_update, :except => { :no_release => true } do
    # do nothing
  end

  task :finalize_update, :roles => :db, :except => { :no_release => true } do
    # do nothing
  end

  task :restart, :roles => :app, :except => { :no_release => true } do
    run "touch #{deploy_to}/current/scripts/production.wsgi"
  end

end

 

配置完了,可以一步一步做部署测试,这样方便查错。直到所有的测试通过,就可以启动整个部署流程。cap deploy

$ cap deploy:setup  #准备目录结构,执行一系列mkdir,如下
[deploy_to]
[deploy_to]/releases
[deploy_to]/releases/20080819001122
[deploy_to]/releases/...
[deploy_to]/shared
[deploy_to]/shared/log
[deploy_to]/shared/pids
[deploy_to]/shared/system
[deploy_to]/current -> [deploy_to]/releases/20100819001122
其中,current和release下面的目录是在部署代码后才有的。

$ cap deploy:check #确认目录读写权限和需要的软件,比如git,rsync
$ cap deploy:update #部署代码
$ cap deploy:restart
$ cap deploy # 启动整个部署流程

 

为了更好的使用capistrano提供的after,before来定制自己部署task,需要了解执行cap deploy之后都有按顺序执行了哪几个具体task。

$ cap deploy
1: deploy:setup
2: deploy:default
    2.1: deploy:update
           2.1.1: deploy:update_code
           2.1.2: deploy:finalize_update
    2.2: deploy:create_symlink
3: deploy:restart

然后就是定制task了,比如可以对Django的manage.py的很多常用参数,或者其他需要的admin操作封装成task,从而可以在指定的多个server上执行同样的管理命令。

比如:migrate, update_cache_all, initialize_db等.

到此为止,整个部署的配置过程结束。

 

ps: Capistrano高级用法 

posted on 2012-07-19 17:46  foxracle  阅读(1574)  评论(1编辑  收藏  举报