不會偷懶的程序猿不是一個好爸爸
capistrano 安裝
# 默認(rèn)安裝最新版,當(dāng)前最新版為3.10.1
gem install capistrano
初始化capistrano項(xiàng)目
mkdir auto_app # 創(chuàng)建項(xiàng)目目錄
cd auto_app
cap install # capistrano 初始化,自動生成配置文件
capistrano 主文件Capfile配置
# Capfile
# Load DSL and set up stages
require "capistrano/setup"
# Include default deployment tasks
require "capistrano/deploy"
# Load the SCM plugin appropriate to your project:
# 【重點(diǎn)】切換成svn協(xié)議 #
require "capistrano/scm/svn"
install_plugin Capistrano::SCM::Svn
Dir.glob("lib/capistrano/tasks/*.rake").each { |r| import r }
config/deploy.rb 發(fā)布文件配置
# deploy.rb
# config valid for current version and patch releases of Capistrano
lock "~> 3.10.1"
# 用戶輸入?yún)?shù) 主要用于多項(xiàng)目處理
# 缺省變量 main_domain 為pika9.com
ask(:main_domain,"pika9.com")
# 缺省變量subdomain 為 www
ask(:subdomain,"www");
# 輸出變量拼接后的結(jié)果汗捡,可忽略
puts "#{fetch(:subdomain)}.#{fetch(:main_domain)}"
# 系統(tǒng)變量配置
set :application, "#{fetch(:subdomain)}.#{fetch(:main_domain)}"
# 設(shè)置項(xiàng)目的svn 路徑
set :repo_url, "svn://code.pika.com//#{fetch(:main_domain)}/#{fetch(:application)}"
# 設(shè)置保留最近幾個版本的代碼
set :keep_releases, 3
# pty暫時不清楚 作用
set :pty, true
# 自動使用svn export 時,使用的賬戶名
set :svn_username, 'deploy'
# 自動使用svn export 時扇住,使用的賬戶密碼
set :svn_password, 'deploy'
# 自動部署完成后春缕,工作代碼所在目錄
set :current_directory,'current'
# 自動部署時,添加的公共目錄
set :shared_directory,'shared'
# set :staging,'production'
# 設(shè)置在目標(biāo)服務(wù)器上代碼的存放路徑
set :deploy_to, "/var/www/#{fetch(:main_domain)}/#{fetch(:application)}"
# 設(shè)置自動部署時自動創(chuàng)建的文件台囱,即共享文件或目錄
append :linked_dirs, "tmp/templates_c"
desc "change tmp dir to nobody"
# 定義一個任務(wù)change2nobody
task :change2nobody do
# 對所有角色均有效
on roles(:all) do
# 修改所有組
execute "chown -R nobody:nobody #{fetch(:deploy_to)}/#{fetch(:shared_directory)}/tmp;"
# 清空編譯緩存
execute "rm -rf #{fetch(:deploy_to)}/#{fetch(:shared_directory)}/tmp/templates_c/*;"
end
end
# 鉤子
# 設(shè)置 在自動部署完成后淡溯,自動執(zhí)行任務(wù) change2nobody
after "deploy:published","change2nobody"
config/deploy/production.rb 目標(biāo)服務(wù)器配置
# 暫時只配置了role
# 一個role代表一臺服務(wù)器
# deploy 為目標(biāo)服務(wù)器上的用戶
# deploy 需要具備:deploy_to 上的所有權(quán)
role :web1, 'deploy@192.168.1.1:22',password: 'deploy'
role :web2, 'deploy@192.168.1.2:22',password: 'deploy'
role :web3 'deploy@192.168.1.3:22',password: 'deploy'
依照上述內(nèi)容配置,即可完成一個簡單的自動部署案例