### 使用標準的命名規范
> There are only two hard problems in computer science: cache invalidation, naming things, and off-by-one errors.
>
> — Phil Karlton
當你維護代碼時會發現,選擇適當而有意義的信息為你的模塊或類命名是有很大幫助的。 尤其是當其他人需要閱讀或基于你編寫的配置清單工作時,這種命名方法是十分必要的。
#### 操作步驟
1. 模塊應該以被管理的軟件或服務命名,例如:apache 或 haproxy。
用跟在模塊之后的功能或提供的服務為模塊中的類命名,例如:apache::vhosts 或 rails::dependencies。
如果在模塊中提供了禁用服務的功能,將其命名為 disabled。例如一個禁用 Apache 的類應該命令為 apache::disabled。
2. 如果一個節點需要提供多種服務,請在節點的定義中包含一個類或者每個服務的類名。例如:
```
node server014 inherits server {
include puppet::server
include mail::server
include repo::gem
include repo::apt
include zabbix
}
```
3. 管理用戶的模塊應該命名為 user。
1. 在 user 模塊中,聲明虛擬用戶的類應命名為 user::virtual。
2. 在 user 模塊中,一個特定的用戶組應該命名為子類,例如 user::sysadmins 或 user::contractors。
4. 當你需要覆蓋某些特定節點或服務的類時,繼承該類并以節點名作為子類名的前綴。 例如,如果節點 cartman 需要一個特殊的 SSH 配置且要覆蓋 ssh 類,可以這樣做:
```
class cartman_ssh inherits ssh {
[ override config here ]
}
```
5. 當使用 Puppet 為不同的服務部署配置時,被 Puppet 解析后傳出的文件應該以服務開頭, 隨后跟上指示文件功能的后綴。例如:
* Apache init 腳本?—?apache.init
* Rails 的日志滾動配置片段?—?rails.logrotate
* Nginx 為 mywizzoapp 應用所做的 vhost 配置?—?mywizzoapp.vhost.nginx
* 獨立運行的 MySQL 服務器的配置?—?standalone.mysql
如果你要管理不同的 Ruby 版本,可以使用添加了版本號的類名,表示由此類負責特定版本的管理, 例如 ruby192 或 ruby186。
#### 更多用法
Puppet 社區維護著一套 Puppet 基礎設施的最佳實踐準則,其中包括對命名的提示: [http://projects.puppetlabs.com/projects/1/wiki/Puppet_Best_Practice2](http://projects.puppetlabs.com/projects/1/wiki/Puppet_Best_Practice2) 。
一些人更愿意在一個節點中使用逗號分割的列表包含多個類,而不是使用分離的 include 語句。例如:
```
node server014 inherits server {
include puppet::server,
mail::server,
repo::gem,
repo::apt,
zabbix
}
```
這是個風格問題,但我更愿意使用分離的 include 語句,一行包含一個模塊或類, 因為這樣可以更容易地在節點之間復制或移動,而無需每次都要整理逗號和縮進的問題。
我在前面的例子中曾幾次提到過繼承。如果你不知道這是什么,不要擔心:我會在下一章詳細解釋。
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者