### 從源碼包自動構建軟件
源碼壓縮包(**tarball**)會嚴重損害你的健康。你既可以使用 **發行版**(**distro**)或第三方軟件包, 同時從源碼包構建你自己的軟件包也是可取的,這有時還會有許多工作要做。 創建 Debian 軟件包(或者其他風格的軟件包)會是一個漫長而容易出錯的過程, 而且你可能沒有時間或預算構建它。
如果你必須從源代碼構建你的程序,至少 Puppet 可以幫你實現這一過程。 一般地構建過程是自動化的,否則你就得手工構建:
* 下載源碼包
* 解壓源碼包
* 配置(Configure)并構建(build)程序
* 安裝已構建的程序
在下面的例子中,我們將從源碼構建 **OpenSSL**(雖然在生產環境中你應該使用發行版提供的軟件包, 但這是一個有用的演示示例)。
#### 操作步驟
1. 添加如下代碼到你的配置清單:
```
exec { "build-openssl":
cwd => "/root",
command => "/usr/bin/wget ftp://ftp.openssl.org/source/
openssl-0.9.8p.tar.gz && /bin/tar xvzf openssl-0.9.8p.tar.
gz && cd openssl-0.9.8p && ./Configure linux-generic32 &&
make install",
creates => "/usr/local/ssl/bin/openssl",
logoutput => on_failure,
timeout => 0,
}
```
2. 運行 Puppet (這可能會執行一段時間!):
```
# puppet agent --test
info: Retrieving plugin
info: Caching catalog for cookbook.bitfieldconsulting.com
info: Applying configuration version '1304954159'
notice: /Stage[main]//Node[cookbook]/Exec[build-openssl]/returns:
executed successfully
notice: Finished catalog run in 554.00 seconds
```
#### 工作原理
exec 命令被 && 運算符分割成了五個階段。也就是說每個階段的命令若執行失敗, 整個命令將會失敗且停止運行。 當你想確保每個子命令都成功運行之后才運行下一個子命令時,這是一種有用的構造方法。
1. 第一階段,下載源碼包:
```
/usr/bin/wget ftp://ftp.openssl.org/source/openssl-0.9.8p.tar.gz
```
2. 第二階段,解壓源碼包:
```
/bin/tar xvzf openssl-0.9.8p.tar.gz
```
3. 第三階段,進入源碼樹的目錄:
```
cd openssl-0.9.8p
```
4. 第四階段,運行配置腳本(通常還會指定一些自定義選項):
```
./Configure linux-generic32
```
5. 最后階段,創建并安裝軟件:
```
make install
```
6. 由于這是一個漫長的過程,你不想每次運行 Puppet 時都運行它,我們指定了一個條件, 即被創建的文件是否應經存在:
```
creates => "/usr/local/ssl/bin/openssl",
```
無論出于任何原因,如果需要重建,你可以刪除此文件。
7. 錯誤并非只發生在首次編譯的情況。在出現問題時,我們指定了 logoutput 參數, 它將為我們顯示編譯或構建過程中的出錯信息:
```
logoutput => on_failure,
```
8. 最后,因為編譯過程可能會持續一段時間,所以將 timeout 參數設置成了 0 (默認情況下,Puppet 執行 exec 命令 5 分鐘后就會超時):
```
timeout => 0,
```
#### 更多用法
如果你有一批必須從源代碼構建的軟件,那么將上述的 exec 放入一個 define 函數會使這一構建過程變得更方便,因為你可以使用大致相同的代碼構建每個包。
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者