### 使用 Foreman
**Foreman** 是一個基于 Web 的類似于 Puppet Dashboard 的 Puppet 管理工具,但它更為雄心勃勃。 Foreman 不僅可以管理 Puppet 報告、節點和配置清單,而且可以為你供應新機器。 如果你需要自動創建大量的服務器或者你需要頻繁地重建服務器,Foreman 將有助于你實現這一過程。
#### 準備工作
1. 在你的系統中添加 Foreman 包的倉庫,參考說明: [http://theforeman.org/projects/foreman/wiki/Installation_instructions](http://theforeman.org/projects/foreman/wiki/Installation_instructions) 。
2. 安裝 Foreman 包:
```
# apt-get update
# apt-get install foreman
```
3. 系統將提示你選擇一種數據庫,請根據需要選擇 mysql、pgsql 或 sqlite。
4. 根據選擇的數據庫,安裝你的數據庫所依賴的軟件包:
```
# apt-get install foreman-mysql
# apt-get install foreman-pgsql
# apt-get install foreman-sqlite3
```
5. 復制文件 /etc/foreman/extras/puppet/foreman/files/foremanreport.rb 到你的 Puppet 自定義報告目錄(通常是 /usr/lib/ruby/1.8/puppet/reports) 并將其重命名為 foreman.rb:
```
# cp /etc/foreman/extras/puppet/foreman/files/foreman-report.rb \
/usr/lib/ruby/1.8/puppet/reports/foreman.rb
```
6. 編輯 foreman.rb 文件設置你的 Foreman 服務器 URL:
```
# URL of your Foreman installation
$foreman_url="http://cookbook.bitfieldconsulting.com:3000"
```
7. 編輯你的 puppet.conf 添加 foreman 報告類型到已啟用的報告類型列表:
```
[master]
reports = store,log,foreman
```
8. 重新啟動 Puppetmaster 使新配置的報告生效。
#### 操作步驟
1. 啟動 Foreman 服務器:
```
# /usr/share/foreman/script/server -e production
```
2. 使用你之前設置的 URL(http://cookbook.bitfieldconsulting.com:3000)瀏覽 Foreman 的 web 界面。
你應該看到如下的 Foreman 初始歡迎界面:

3. 現在,在一個客戶端運行 Puppet:
```
# puppet agent --test
```
在 Foreman 的 Web 界面中進入 **Reports** 標簽頁,如圖所示,你會看到剛剛運行的客戶報告:

4. 進入 Dashboard 標簽頁你會看到一個針對所有客戶的 **OVERVIEW** (本例中只有一個客戶)。

#### 更多用法
此處我們僅僅接觸到了 Foreman 的一些基本功能。既然已經運行了一個配置好的 Foreman, 你就可以嘗試不同的報告、圖表、以及 Foreman 提供的其他信息。 當你有很多主機需要管理,并希望看到 Puppet 如何跨越整個網絡的運行統計時, 這些信息會變得更有價值。
Foreman 的另一個主要特性是供應:它可以使用 PXEboot 和 Kickstart 從頭創建物理服務器或虛擬服務器,對 Puppet 證書進行自動簽名,并運行 Puppet 將機器帶入生產狀態。 欲了解更多有關如何實現的詳細信息,請查閱 Foreman 文檔: [http://theforeman.org/projects/foreman/wiki/Unattended_installations](http://theforeman.org/projects/foreman/wiki/Unattended_installations) 。
> 
> 如果你決定將 Foreman 用于生產環境,就值得為其設置 Apache 虛擬主機, 而不是使用 Webrick 帶動 Foreman。 Webrick 對測試環境很有用,但它不是真正的生產級別的 Web 服務器。
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者