### 使用 Augeas 自動修改配置文件
當然,有關標準的事物是如此之多。有時每個應用程序的配置格式都略有不同, 書寫正則表達式來解析和修改所有這些配置文件是一項很煩人的工作。
幸好 Augeas 在這方面可以幫助我們。Augeas 是一個旨在簡化使用不同配置文件格式工作的工具, 它將不同格式的配置文件統一呈現為一個簡單的包含所有配置項的樹狀結構。 Puppet 的 Augeas 支持允許你創建 augeas 資源,它可以智能地自動地為所需的配置做相應的改變。
#### 準備工作
在使用 Augeas 之前需要先安裝它。如下的 Puppet 代碼將添加 Augeas 到你的配置。
1. 使用如下內容創建 /etc/puppet/modules/admin/manifests/augeas.pp 文件:
```
class admin::augeas {
package { [ "augeas-lenses",
"augeas-tools",
"libaugeas0",
"libaugeas-ruby1.8" ]:
ensure => "present"
}
}
```
2. 在一個節點上包含此類:
```
node cookbook {
include admin::augeas
}
```
3. 運行 Puppet:
```
# puppet agent --test
info: Retrieving plugin
info: Caching catalog for cookbook.bitfieldconsulting.com
info: Applying configuration version '1303657095'
notice: /Stage[main]/Admin::Augeas/Package[augeas-tools]/ensure:
ensure changed 'purged' to 'present'
notice: Finished catalog run in 21.96 seconds
```
#### 操作步驟
1. 使用如下內容創建 /etc/puppet/modules/admin/manifests/ipforward.pp 文件:
```
class admin::ipforward {
augeas { "enable-ip-forwarding":
context => "/files/etc/sysctl.conf",
changes => [
"set net.ipv4.ip_forward 1",
],
}
}
```
2. 在一個節點上包含此類:
```
node cookbook {
include admin::augeas
include admin::ipforward
}
```
3. 運行 Puppet:
```
# puppet agent --test
info: Retrieving plugin
info: Caching catalog for cookbook.bitfieldconsulting.com
info: Applying configuration version '1303729376'
notice: /Stage[main]/Admin::Ipforward/Augeas[enable-ipforwarding]/
returns: executed successfully
notice: Finished catalog run in 3.53 seconds
```
4. 使用如下命令檢查配置是否生效:
```
# sysctl -p |grep forward
net.ipv4.ip_forward = 1
```
#### 工作原理
下面將描述前面的代碼是如何工作的:
1. 我們聲明了一個名為 enable-ip-forwarding 的 augeas 資源:
```
augeas { "enable-ip-forwarding":
```
2. 我們指定要實施改變的文件 /etc/sysctl.conf:
```
context => "/files/etc/sysctl.conf",
```
3. 將我們需要改變的設置作為一個數組(本例中只有一個數組元素)傳遞給 changes 參數:
```
changes => [
"set net.ipv4.ip_forward 1",
],
```
通常使用 Augeas 改變設置需用如下的格式:
```
set <parameter> <value>
```
Augeas 使用一套名為 **lenses** 的轉換文件,使其能夠為給定的配置文件以適當的格式改寫設置。 在本例中,此設置將轉換為 /etc/sysctl.conf 文件中的如下一行:
```
net.ipv4.ip_forward=1
```
#### 更多用法
之所以使用 /etc/sysctl.conf 文件做例子,是因為它包含了各種各樣的內核設置, 你可能想要在不同的 Puppet 類中因各種不同的目的而改變這些設置。 在前面的例子中,我們為一個路由器的類啟用了 IP 轉發, 然而你也可以為一個負載均衡的類調整 net.core.somaxconn 的值。
這意味著簡單地對 /etc/sysctl.conf 文件“Puppet化”("Puppetizing") 并分發它不能勝任所有的情況,因為你要修改的設置根據不同的服務需求可能會有不同, 從而引發版本沖突。Augeas 則是這種情況的正確解決方案,因為你可以在不同的位置定義 augeas 資源去修改相同的配置文件,這樣就不會引起沖突。
Augeas 是個強大的工具,使用 lenses 可以轉換絕大多數標準的 Linux 配置文件, 而且如果需要管理自己的專有格式的配置文件,你也可以書寫自己的專有配置格式。 更多關于使用 Puppet 和 Augeas 的信息,請訪問 Puppet Labs 的 wiki 頁面: [http://projects.puppetlabs.com/projects/1/wiki/Puppet_Augeas](http://projects.puppetlabs.com/projects/1/wiki/Puppet_Augeas) 。
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者