什麼是NFS?
NFS(Network File System,網絡文件系統),是FreeBSD支持的文件系統中的一種,它容許網絡中的計算機之間經過TCP/IP網絡共享資源。在NFS的應用中,本地NFS的客戶端應用能夠透明地讀寫位於遠端NFS服務器上的文件,就像訪問本地文件同樣vim
NFS的應用場景
A,B,C三臺機器上須要保證被訪問到的文件是同樣的,A共享數據出來,B和C分別去掛載A共享的數據目錄,從而B和C訪問到的數據和A上的一致服務器
NFS的工做原理
遠程客戶端進行nfs請求,RPC得到請求,通知PORTMAP(rpcbind)來獲取端口號,而後PORTMAP(rpcbind)將可用的端口號傳給NFS、RPC,而後NFS模塊再進行權限檢驗,若是有足夠的權限,RPC就經過PORTMAP給出的端口進行數據傳輸,並經過該端口到達客戶端。
網絡
兩臺機器
A機器IP:192.168.71.131 服務端
B機器IP:192.168.71.132 客戶端async
A機器 安裝 nfs-utils 和 rpcbind 這兩個包,執行以下命令yum install -y nfs-utils rpcbind
ide
B機器 安裝 nfs-utils 這個包,執行以下命令yum install -y nfs-utils
ui
A機器 編輯文件
vim /etc/exports3d
在文件中加入1行:/home/nfstestdir 192.168.71.132/24(rw,sync,all_squash,anonuid=1000,anongid=1000)
code
A機器 建立分享的目錄並更改權限爲777mkdir /home/nfstestdir
chmod 777 /home/nfstestdir
blog
A機器 啓動NFS服務systemctl start nfs
內存
A機器 設置NFS開機啓動systemctl enable nfs
rw 讀寫
ro 只讀
sync 同步模式,內存數據實時寫入磁盤
async 非同步模式
no_root_squash 客戶端掛載NFS共享目錄後,root用戶不受約束,權限很大
root_squash 與上面選項相對,客戶端上的root用戶收到約束,被限定成某個普通用戶
all_squash 客戶端上全部用戶在使用NFS共享目錄時都被限定爲一個普通用戶
anonuid/anongid 和上面幾個選項搭配使用,定義被限定用戶的uid和gid
客戶端掛載
showmount命令用於查詢NFS服務器的相關信息
查看通信是否正常,B機器上執行命令showmount -e 192.168.71.131
showmount -e 顯示NFS服務器的輸出清單
若是出現報錯,注意下防火請是否關閉
B機器 掛載磁盤,將磁盤掛載到mount下mount -t nfs 192.168.71.131:/home/nfstestdir /mnt/