### 使用 Puppet Dashboard
**Puppet Dashboard** 是一個管理 Puppet 安裝的有用的工具,尤其對于大量的安裝, 并且能夠通過一個 Web 界面看到節點的信息和報告。 **Puppet Dashboard** 可以為你顯示最近運行 Puppet 的節點,它們運行了多長時間, 是否有任何節點的錯誤報告,以及是否有一段時間內沒有運行 Puppet 的節點等。
#### 準備工作
1. 從 Puppet Labs 站點 [http://www.puppetlabs.com/misc/download-options/](http://www.puppetlabs.com/misc/download-options/) 下載 Puppet Dashboard 軟件包并解壓縮。 軟件包中有一個安裝說明文件 README.markdown,但你可能需要先安裝以下依賴的包(部分或全部):
```
# apt-get install -y build-essential irb libmysql-ruby
libmysqlclient-dev libopenssl-ruby libreadline-ruby mysql-server
rake rdoc ri ruby ruby-dev
```
2. 為 Puppet Dashboard 應用程序創建一個 MySQL 數據庫和用戶(使用自己的口令):
```
# mysql -uroot
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 39
Server version: 5.1.41-3ubuntu12.9 (Ubuntu)
Type 'help;' or '\h' for help. Type '\c' to clear the current
input statement.
mysql> create database dashboard;
Query OK, 1 row affected (0.00 sec)
mysql> grant all on dashboard.* to dashboard@localhost identified
by 'topsecret';
Query OK, 0 rows affected (0.01 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
```
3. 復制 Puppet Dashboard 提供的樣例文件 database.yml,并做適當的修改:
```
# cd puppetlabs-puppet-dashboard-071acf4
# cp config/database.yml.example config/database.yml
# vi config/database.yml
```
```
production:
database: dashboard
username: dashboard
password: topsecret
encoding: utf8
adapter: mysql
```
4. 使用應用程序提供的 Rake 任務創建如下的初始化數據庫:
```
# rake RAILS_ENV=production db:migrate
```
#### 操作步驟
1. 啟動內置的 Web 服務器:
```
# script/server -e production
=> Booting WEBrick
=> Rails 2.3.5 application starting on http://0.0.0.0:3000
=> Call with -d to detach
=> Ctrl-C to shutdown server
[2011-02-21 09:54:32] INFO WEBrick 1.3.1
[2011-02-21 09:54:32] INFO ruby 1.8.7 (2010-01-10) [i486-linux]
[2011-02-21 09:54:37] INFO WEBrick::HTTPServer#start: pid=16570
port=3000
Using a web browser, connect to localhost:3000
```
2. 如圖所示,你應該看到 Puppet Dashboard 的界面:

3. 現在你需要配置 Puppetmaster 向 Puppet Dashboard 發送報告。 為了實現這個功能,你需要配置 puppet.conf 文件的 reports 參數,為其添加 http 報告:
```
reports = http,log
```
4. 重新啟動 Puppetmaster 使新配置的報告生效。
5. 在節點上運行 Puppet:
```
# puppet agent --test
```
6. 在 Puppet Dashboard 界面中單擊 **Nodes** 鏈接。 如圖所示,你應該看到表明 Puppet 運行成功的綠色區域:

#### 工作原理
當在一個節點上運行了 Puppet,它會使用其報告裝置向 Puppet Dashboard 發送報告。 Puppet Dashboard 會存儲這些數據并利用這些數據顯示所有節點上的 Puppet 活動的圖表和摘要。
#### 更多用法
你也可以使用 Puppet Dashboard 創建新的節點或類,并控制哪些節點需要包含哪些類。 實際上,它為你管理 Puppet 配置清單提供了一個 Web 接口, 所以你可以通過 Web 瀏覽器來編輯配置清單,而不是直接修改文本文件。 這是一個有吸引力的功能,尤其用于想讓其他團隊或部門的人能夠管理他們自己的 Puppet 配置時。
為了實現 Puppet Dashboard 的這個功能,你需要配置 Puppet 使用 **external node classifier**; 這將在 [使用外部節點分類器](#ch09sec09) 一節中介紹。
#### 參見本書
* 第 2 章的 [生成報告](#ch02sec01) 一節
* 第 2 章的 [創建圖形化報告](#ch02sec03) 一節
* 本章的 [使用外部節點分類器](#ch09sec09) 一節
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者