### 管理 NFS 服務和文件共享
> There are three kinds of death in this world. There’s heart death, there’s brain death, and there’s being off the network.
>
> — Guy Almes
網絡文件系統(**Network File System**,**NFS**)是一種從遠程服務器掛裝共享目錄的方法。 例如:一批 web 服務器可以掛裝同一個 NFS 共享為客戶供應靜態資產文件,比如圖片文件和 CSS 文件。 盡管 NFS 是一種比較舊的技術,但它仍被廣泛使用著, 所以本處方將向你展示如何創建一個 NFS 服務器以及如何通過它來共享文件。
#### 操作步驟
1. 創建一個 nfs 模塊:
```
# mkdir /etc/puppet/modules/nfs
# mkdir /etc/puppet/modules/nfs/manifests
```
2. 使用如下內容創建 /etc/puppet/modules/nfs/manifests/init.pp 文件:
```
class nfs {
package { "nfs-kernel-server": ensure => installed }
service { "nfs-kernel-server":
ensure => running,
enable => true,
hasrestart => true,
require => Package["nfs-kernel-server"],
}
file { "/etc/exports.d":
ensure => directory,
}
exec { "update-etc-exports":
command => "/bin/cat /etc/exports.d/* >/etc/exports",
notify => Service["nfs-kernel-server"],
refreshonly => true,
}
define share( $path, $allowed, $options = "" ) {
include nfs
file { $path:
ensure => directory,
}
file { "/etc/exports.d/${name}":
content => "${path} ${allowed}(${options})\n",
notify => Exec["update-etc-exports"],
}
}
}
```
3. 在你需要輸出 NFS 共享的節點上添加如下代碼(修改 IP 地址范圍以適應你的網絡):
```
nfs::share { "data":
path => "/data",
allowed => "10.0.2.0/24",
options => "rw,sync,no_root_squash",
}
nfs::share { "data2":
path => "/data2",
allowed => "10.0.2.0/24",
options => "rw,sync,no_root_squash",
}
```
4. 運行 Puppet:
```
# puppet agent --test
info: Retrieving plugin
info: Caching catalog for cookbook.bitfieldconsulting.com
info: Applying configuration version '1311526219'
notice: /Stage[main]/Nfs/Package[nfs-kernel-server]/ensure:
created
notice: /Stage[main]/Nfs/Service[nfs-kernel-server]/ensure: ensure
changed 'stopped' to 'running'
notice: /Stage[main]//Node[cookbook]/Nfs::Share[data2]/File[/
data2]/ensure: created
notice: /Stage[main]//Node[cookbook]/Nfs::Share[data2]/File[/etc/
exports.d/data]/ensure: defined content as '{md5}408f8b40815ff4b6e
ec2f324ca7eafc4'
info: /Stage[main]//Node[cookbook]/Nfs::Share[data]/File[/etc/
exports.d/data]: Scheduling refresh of Exec[update-etc-exports]
notice: /Stage[main]//Node[cookbook]/Nfs::Share[data2]/
File[/etc/exports.d/data2]/ensure: defined content as '{md5}
ec2f324ca7eafc4408f8b40815ff4b6e'
info: /Stage[main]//Node[cookbook]/Nfs::Share[data2]/File[/etc/
exports.d/data2]: Scheduling refresh of Exec[update-etc-exports]
notice: /Stage[main]/Nfs/Exec[update-etc-exports]: Triggered
'refresh' from 2 events
info: /Stage[main]/Nfs/Exec[update-etc-exports]: Scheduling
refresh of Service[nfs-kernel-server]
notice: /Stage[main]/Nfs/Service[nfs-kernel-server]/ensure: ensure
changed 'stopped' to 'running'
notice: /Stage[main]/Nfs/Service[nfs-kernel-server]: Triggered
'refresh' from 1 events
notice: Finished catalog run in 3.13 seconds
```
5. 通過在另一個服務器上掛裝共享測試 NFS 的輸出配置:
```
# mkdir /mnt/data
# mount cookbook:/data /mnt/data
# ls /mnt/data
```
#### 工作原理
nfs 類用于安裝并啟動 nfs-kernel-server 服務,此服務監聽網絡文件共享的連接。 還定義了一個 nfs::share 資源,你可以在配置清單中的任何位置使用它輸出一個 NFS 目錄:
```
nfs::share { "data":
path => "/data",
allowed => "10.0.2.0/24",
options => "rw,sync,no_root_squash",
}
```
此資源的名字是任何你想要給出的一個標簽:本例中為 data。path 用于指定要共享的目錄。 allowed 參數可以使用一個 CIDR 網絡地址(正向本例中的 10.0.2.0/24)、 一個 IP 地址、一個主機名或一個用空格間隔的 IP 地址或主機名列表。 NFS 服務器僅允許由指定的主機遠程掛裝此資源。
options 參數用于指定 NFS 的掛裝選項(這些參數將出現在 /etc/exports 文件中, 可使用命令 man exports 查看這些選項的精確細節)。
請注意,我們使用了與 rsyncd.conf 例子相同的片斷模式。 nfs::share 的任何一個實例都會創建 /etc/exports.d 目錄下的一個配置文件片段, 這會觸發一個 exec 資源將所有的配置文件片段串連成一個 /etc/exports 配置文件并通知 NFS 服務應用配置的改變。
#### 更多用法
NFS 共享只能應用于應用程序的非關鍵性數據,因為 NFS 服務器會造成單點故障。 你可以使用集群文件系統解決關鍵性數據的共享,應該考慮使用 GlusterFS 替代 NFS。
- 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
- 使用公共模塊
- 使用外部節點分類器
- 創建自定義的資源類型
- 創建自定義的提供者