### 使用 Rake 部署變更
每個人的生活都離不開鍵盤,但我討厭不必要的敲打。 如果你按照 [使用版本控制](#ch01sec01) 一節所描述的工作流程工作, 可以添加一些自動化任務使這個處理過程更加容易。 有許多工具可以幫助我們在遠程機器上執行命令,包括 Capistrano([https://github.com/capistrano/capistrano](https://github.com/capistrano/capistrano))和 Fabric([https://github.com/fabric/fabric](https://github.com/fabric/fabric)),但在本例中,我們將使用 Rake([http://rake.rubyforge.org/](http://rake.rubyforge.org/))。
#### 準備工作
若你還沒有安裝 Rake, 運行如下的命令:
```
apt-get install rake
```
執行這個命令,你需要一個 Internet 連接。
#### 操作步驟
1. 在你的 Puppet 配置清單工作副本的頂級目錄下創建一個名為 Rakefile 的文件,例如:
```
john@laptop:~/puppet-work$ vi Rakefile
```
文件內容看上去像這樣:
```
PUPPETMASTER = 'cookbook'
SSH = 'ssh -t -A'
task :deploy do
sh "git push"
sh "#{SSH} #{PUPPETMASTER} 'cd /etc/puppet && sudo git pull'"
end
```
2. 當你在本地副本上應用 Puppet 配置清單的改動時,可以簡單地運行命令:
```
$ rake deploy
```
3. Rake 會更新遠程 Git 倉庫并刷新 Puppetmaster 的工作目錄副本:
```
$ git push
Counting objects: 4, done.
Delta compression using 2 threads.
Compressing objects: 100% (3/3), done.
Writing objects: 100% (3/3), 452 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
To ssh:/ /git@cookbook.bitfieldconsulting.com/var/git/cookbook
561e5a6..a8b8c76 master -> master
ssh -A -l root cookbook 'cd /etc/puppet && git pull'
From ssh://cookbook.bitfieldconsulting.com/var/git/cookbook
561e5a6..a8b8c76 master -> origin/master
Updating 561e5a6..a8b8c76
Fast-forward
Rakefile | 6 ++++++
1 files changed, 6 insertions(+), 0 deletions(-)
create mode 100644 Rakefile
```
4. 你還可以添加一個 Rake 任務用于在客戶端上運行 Puppet:
```
task :apply => [:deploy] do
client = ENV['CLIENT']
sh "#{SSH} #{client} 'sudo puppet agent --test'" do |ok,
status|
puts case status.exitstatus
when 0 then "Client is up to date."
when 1 then "Puppet couldn't compile the manifest."
when 2 then "Puppet made changes."
when 4 then "Puppet found errors."
end
end
end
```
5. 當你要在指定客戶端上測試你所做的變更時,可以運行如下的命令:
```
rake CLIENT=cookbook apply
```
替換 cookbook 為你客戶端的名字,或設置 CLIENT 環境變量,使 Rake 知道你要在哪個客戶機上運行 Puppet。
```
info: Caching catalog for cookbook
info: Applying configuration version '1292865016'
info: Creating state file /var/lib/puppet/state/state.yaml
notice: Finished catalog run in 0.03 seconds
```
6. 如果你只想查看 Puppet 將會做些什么,而不是實際應用這些變更, 你可以使用 --noop 標志:
```
task :noop => [:deploy] do
client = ENV['CLIENT']
sh "#{SSH} #{client} 'sudo puppet agent --test --noop'"
end
```
7. 現在你可以運行:
```
$ rake noop
```
這將會顯示一個變更預覽。
#### 工作原理
一個 Rakefile 文件由若干任務組成,任務由關鍵字 task 來標識。 任務定義了一系列的操作步驟,在本例中,使用一系列的 shell 命令推送你的配置清單到主版本倉庫, 然后更新 Puppetmaster 上的工作副本。
任務可以互相引用,因為一個任務可能會依賴其它任務。例如,在我們的 Rakefile 中, apply 任務引用了 deploy 任務,每當你運行 rake apply ,Rake 會先確保完成 deploy 任務,然后再執行 apply 任務。
#### 更多用法
你可以擴展這個 Rakefile 實現更多的自動化任務,包括在更新 Puppet 配置清單之前運行語法檢查, 甚至可以在引導啟動過程中使用 Puppet 來初始化你的新機器。 Rake 是一個功能強大的工具,在使用 Puppet 管理大型網絡時會為我們提供很大的幫助。
#### 參見本書
* 本章的 [使用版本控制](#ch01sec01) 一節
* 本章的 [創建去中心化的分布式 Puppet 架構](#ch01sec10) 一節
* 本章的 [使用提交鉤子](#ch01sec02) 一節
- Puppet 2.7 Cookbook 中文版
- 中文翻譯版
- 譯者序
- 項目緣起
- 翻譯方法
- 社區鏈接
- 社區建議
- 貢獻者
- 原書版權頁
- 關于作者
- 前言
- 本書內容
- 閱讀前提
- 適用讀者
- 格式約定
- 讀者反饋
- 客戶支持
- 下載案例代碼
- 勘誤表
- Puppet 基礎設施
- 使用版本控制
- 使用提交鉤子
- 使用 Rake 部署變更
- 配置 Puppet 的文件服務器
- 從 cron 運行 Puppet
- 使用自動簽名
- 預簽名證書
- 從 Puppet 的 filebucket 檢索文件
- 使用 Passenger 擴展 Puppet 的部署規模
- 創建去中心化的分布式 Puppet 架構
- 監控、報告和排錯
- 生成報告
- 通過 Email 發送包含特定標簽的日志信息
- 創建圖形化報告
- 自動生成 HTML 文檔
- 繪制依賴關系圖
- 測試你的 Puppet 配置清單
- 執行模擬運行
- 檢測編譯錯誤
- 理解 Puppet 的錯誤信息
- 顯示命令的輸出結果
- 輸出調試信息
- 檢查配置設置
- 使用標簽
- 使用運行階段
- 使用不同的環境
- Puppet 語言及其寫作風格
- 使用 Puppet 社區規范
- 使用模塊
- 使用標準的命名規范
- 使用嵌入式 Ruby 代碼
- 使用純 Ruby 代碼書寫配置清單
- 遍歷多個項目
- 書寫強大的條件語句
- 在 if 語句中使用正則表達式
- 使用選擇器和 case 語句
- 檢測字符串中是否包含指定的值
- 使用正則表達式替換
- 書寫更優質的配置清單
- 使用資源的數組
- 使用 define 資源
- 指定資源的依賴關系
- 使用節點繼承
- 使用類的繼承和重載
- 給類傳遞參數
- 書寫可重用的跨平臺配置清單
- 獲得系統的環境信息
- 導入動態信息
- 從 CSV 文件導入數據
- 給 Shell 命令傳遞參數
- 使用文件和軟件包
- 為配置文件添加配置行
- 使用 Augeas 自動修改配置文件
- 使用配置片段構建配置文件
- 使用 ERB 模板
- 在模板中遍歷數組
- 從第三方倉庫安裝軟件包
- 配置 APT 軟件倉庫
- 配置 GEM 倉庫
- 從源碼包自動構建軟件
- 比較軟件包的版本
- 用戶和虛擬資源
- 使用虛擬資源
- 使用虛擬資源管理用戶
- 管理用戶基于密鑰的 SSH 訪問
- 管理用戶的自定義文件
- 有效地分發 cron 任務
- 當文件更新時運行命令
- 使用主機資源
- 為文件資源指定多個源
- 使用文件資源遞歸地分發整個目錄樹
- 清理過期的舊文件
- 使用日程表資源
- 資源的審計
- 臨時禁用資源
- 管理時區
- 應用程序
- 管理 Apache 服務
- 創建 Apache 虛擬主機
- 創建 Nginx 虛擬主機
- 創建 MySQL 數據庫及用戶
- 管理 Drupal 站點
- 管理 Rails 應用程序
- 服務器和云基礎設施
- 部署 Nagios 監控服務器
- 使用 Heartbeat 構建高可用服務
- 管理 NFS 服務和文件共享
- 使用 HAProxy 為多個 web 服務器實現負載均衡
- 使用 iptables 管理防火墻
- 管理 Amazon 的 EC2 實例
- 使用 Vagrant 管理虛擬機
- 外部工具和 Puppet 生態環境
- 創建 Facter 的自定義 fact
- 在運行 Puppet 之前和之后執行命令
- 從 Shell 會話生成 Puppet 配置清單
- 從運行的系統上生成 Puppet 配置清單
- 使用 Puppet Dashboard
- 使用 Foreman
- 使用 MCollective
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者