### 從 Shell 會話生成 Puppet 配置清單
> I object to being called a chess genius, because I consider myself to be an all around genius who just happens to play chess, which is rather different.
>
> — Bobby Fischer
并非所有人都是天才。如果你確切地知道安裝一個應用程序或服務都需要做些什么的話, 你馬上就可以創建 Puppet 的配置清單。盡管如此,你通常還是需要首先做些小小的試驗, 比如找到你要安裝的軟件包、需要編輯哪些配置文件等等。 你可以使用 script 命令記錄你的 Shell 會話,然后根據會話文件的記錄內容開發 Puppet 的配置清單,這是個不錯的方法。
但如果有一個工具能通過讀取你的會話文件生成 Puppet 配置清單的話是不是更精彩呢? 為了實現此功能,**cft** (讀音為 'sift')應運而生。 一旦你激活它,cft 監視你的 Shell 會話并記住你安裝的任何軟件包、任何服務的配置、 任何你創建或編輯的文件,等等。 當會話記錄結束,cft 會生成一個重現你剛剛所做的所有改變的完整的 Puppet 配置清單。
#### 準備工作
1. 當前完整的 cft 支持僅能用于 Red Hat/CentOS 發行版;針對 Debian/Ubuntu 發行版的完整的支持正在開發中,估計不久之后即可完成。 如果你正在使用 Red Hat/CentOS,只要安裝 cft 即可:
```
# yum install cft
```
2. 對于 Debian/Ubuntu 系統,請參考如下安裝說明,網址為: [http://fmtyewtk.blogspot.com/2011/01/porting-cft-to-debian.html](http://fmtyewtk.blogspot.com/2011/01/porting-cft-to-debian.html) 。
#### 操作步驟
1. 在本例中我們將使用 cft 監視 NTP 安裝的軟件包并生成實現相同功能的配置清單。
```
# cft begin ntp
# apt-get install ntp
Reading package lists... Done
Building dependency tree
Reading state information... Done
Suggested packages:
ntp-doc
The following NEW packages will be installed:
ntp
0 upgraded, 1 newly installed, 0 to remove and 385 not upgraded.
Need to get 517kB of archives.
After this operation, 1,323kB of additional disk space will be used.
Get:1 http://us.archive.ubuntu.com/ubuntu/ lucid/main ntp
1:4.2.4p8+dfsg-1ubuntu2 [517kB]
Fetched 517kB in 5s (101kB/s)
Selecting previously deselected package ntp.
(Reading database ... 135278 files and directories currently
installed.)
Unpacking ntp (from .../ntp_1%3a4.2.4p8+dfsg-1ubuntu2_i386.deb)
...
Processing triggers for man-db ...
Processing triggers for ureadahead ...
ureadahead will be reprofiled on next reboot
Setting up ntp (1:4.2.4p8+dfsg-1ubuntu2) ...
* Starting NTP server ntpd
# vi /etc/ntp.conf
# service ntp restart
* Stopping NTP server ntpd
[ OK ]
* Starting NTP server ntpd
# cft finish ntp
# cft manifest ntp
class ntp {
package { 'ntp':
ensure => '1:4.2.4p8+dfsg-1ubuntu2'
}
service { 'ntp':
enable => 'true',
ensure => 'running'
}
file { '/etc/ntp.conf':
group => 'root',
owner => 'root',
mode => '0644',
source => '/tmp/cft/ntp/after/etc/ntp.conf'
}
}
```
#### 工作原理
首先告訴 cft 開始記錄系統的改變,并將其會話存儲在 ntp 中?—?cft begin ntp 。
然后,當你安裝 ntp 軟件包時,cft 會記錄這個事實。 軟件包安裝了服務的啟動腳本,配置了在機器啟動時啟動服務,cft 同時也記錄了這些。 最后,cft 注意到你編輯了 /etc/ntp.conf 文件,并保存了一份修改后的拷貝以備后用。
當你運行 cft finish ntp 命令,這會停止記錄變化。 現在你可以使用 cft manifest ntp 命令生成與你的控制臺會話等效的 Puppet 配置清單。
正如你看到的,生成的配置清單包括了 package 聲明(由命令 apt-get install ntp 觸發):
```
package { 'ntp':
ensure => '1:4.2.4p8+dfsg-1ubuntu2'
}
```
同時包括了再現包安裝腳本作用的 service 聲明,啟動服務并設置開機啟動:
```
service { 'ntp':
enable => 'true',
ensure => 'running'
}
```
這個聲明是由于你手動配置了如下命令所生成的:
```
# service ntp start
# update-rc.d ntp defaults
```
配置清單的最后一部分封裝了 ntp.conf 文件的改變。 cft 只知道你對這個文件做了改變,但不知道你具體做了哪些改變, 所以 cft 將修改后的整個文件做為一個拷貝,并使其可以通過 Puppet 分發這個文件:
```
file { '/etc/ntp.conf':
group => 'root',
owner => 'root',
mode => '0644',
source => '/tmp/cft/ntp/after/etc/ntp.conf'
}
```
當你將此配置清單放入 Puppet,還需要從原始路徑(/tmp/cft/ntp/after/etc/ntp.conf) 復制 ntp.conf 文件到你的模塊樹的適當位置,并根據這個位置修改 source 參數的值。
#### 更多用法
cft 是快速生成 Puppet 配置清單原型的一個強大工具。 你可以找一臺構建配置清單的主機,盡可能使用 cft 記錄你的安裝和配置過程, 并使用它對整個會話進行編碼生成 Puppet 的配置清單。 雖然這還需要一些額外的編輯工作,但是比你從頭開始編寫配置清單要快得多。
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者