### 配置 Puppet 的文件服務器
部署配置文件是 Puppet 最常見的用途之一。許多服務都需要一些配置文件, 你可以讓 Puppet 使用 file 資源將這些配置文件推送到客戶端,如下面的代碼所示:
```
file { "/opt/nginx/conf.d/app_production.conf":
source => "puppet:///modules/app/app_production.conf",
}
```
source 參數是這樣約定的: puppet:/// 之后的第一部分假定是一個 **掛裝點(mount point)** 名稱,其余部份被視為一個文件路徑,如下所示:
```
puppet:///<mount point>/<path>
```
通常 <mount point> 的值是一個模塊名稱,如上例所示。在這個例子中, Puppet 將在如下的位置查找文件:
```
manifests/modules/app/files/app_production.conf
```
modules 是 Puppet 予以特別對待的一個掛裝點:它期望接下來的路徑組成是一個模塊名, 并在模塊的 files 目錄下針對路徑的其余部分尋找文件。
然而 Puppet 也允許你創建自定義的掛裝點,你可以為自定義的掛裝點設置個別的訪問控制, 并將其映射到 Puppetmaster 的不同文件系統位置。 在本節中,我們將展示如何創建和配置這些自定義的掛載點。
#### 操作步驟
1. 在 PuppetMaster 的 fileserver.conf 中添加新的一節,將掛裝點的名稱用方括號括起, path 的值就是 Puppet 將會尋找數據的目錄路徑,如下所示:
```
[san]
path /mnt/san/mydata/puppet
```
2. 在你的配置清單里,使用 source 指定你的掛載點名稱,如下所示:
```
source => "puppet:///san/admin/users.htpasswd",
```
Puppet 會將其轉換為如下的路徑:
```
/mnt/san/mydata/puppet/admin/users.htpasswd
```
像這樣創建一個自定義掛載點的主要原因就是提高安全性。 例如,你有個秘密的口令文件只需部署到 web 服務器,而其它機器則不需要。 如果有人能夠在任何機器上運行 Puppet,并且有合法的證書訪問 Puppetmaster, 那么沒有人能阻止他像這樣執行下面的配置清單:
```
file { "/home/cracker/goodstuff/passwords.txt":
source => "puppet:///web/passwords.txt",
}
```
他們可以輕而易舉地獲取秘密數據。事實上,可以導出 Puppet 倉庫的任何人以及 在 Puppetmaster 上有賬戶的任何人都可以訪問此文件。 為了避免這種情況發生的方法之一就是將秘密數據放在自定義掛載點并啟用訪問控制。
3. 在 fileserver.conf 中添加 allow 和 deny 參數來定義你的掛載點,如下所示:
```
[secret]
/data/secret
allow web.example.com
deny *
```
#### 工作原理
在本例中, 僅允許 web.example.com 訪問此文件。 默認的策略是拒絕所有的訪問, 因此 deny * 這行是可選的,但它確實是個好的習慣,因為看上去更清晰。 之后 web 服務器就可以使用 file 資源了,如下所示:
```
file { "/etc/passwords.txt":
source => "puppet:///secret/passwords.txt",
}
```
如果此配置清單是在 web.example.com 上執行,將會正常工作; 若在其它客戶端上執行則執行失敗。
#### 更多用法
你也可以將指定的 IP 地址替換為主機名,也可使用 **無類型域間路由(CIDR)** 或使用通配符(wildcard)來表示一組地址,如下所示:
```
allow 10.0.55.0/24
allow 192.168.0.*
```
#### 參見本書
* 第 3 章的 [使用模塊](#ch03sec02) 一節
* 第 6 章的 [使用文件資源遞歸地分發整個目錄樹](#ch06sec09) 一節
* 第 6 章的 [為文件資源指定多個源](#ch06sec08) 一節
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者