NAS數據存儲之NFS搭建和使用

NFS是主流異構平臺的共享文件系統之一,能夠支持在不同類型的系統之間通過網絡進行文件共享,允許一個系統在網絡上與他人共享目錄和文件 。NFS傳輸協議用于服務器和客戶機之間的文件訪問和共享通信,從而使客戶機進程訪問保存在存儲設備上的數據,掛載成功的情況下,在客戶機掛載的目錄中操作,如增刪改文件或目錄,服務器也同樣生效 。以下就是NFS的搭建方式和遇到的問題分享 。
一,環境準備VMware創建兩臺虛擬機,我選擇的是centos7,如果需要新創建虛擬機,按照網上的教程 , 編輯/etc/sysconfig/network-scripts/ifcfg-ens33文件,設置虛擬機的ip固定 。我主備的環境是服務器端:192.168.229.129,客戶機端:192.168.229.130 。盡量讓兩個版本一致,不一致的,比如服務器端是centos8,就出現了奇奇怪怪的問題,后面再詳細說一下 。

NAS數據存儲之NFS搭建和使用

文章插圖
 二,分別在兩臺機器安裝rpcbind、nfs-utils因為centos7也算是比較老的版本了,而且我選擇的鏡像也比較簡單,這兩個服務都沒有安裝,通過yum命令來做 , 即 yum -y install rpcbind nfs-utils 。如果新環境yum有問題,ping www.baidu.com 等不行,也許是dns的解析文件沒有配置,我做了如下配置 , 修改/etc/resolv.conf,兩個地址是windows命令行使用ipconfig -all查詢的本地電腦的dns解析地址 。
NAS數據存儲之NFS搭建和使用

文章插圖
 
NAS數據存儲之NFS搭建和使用

文章插圖
 三,服務器端創建要共享的目錄,并設置權限為777mkdir /data/share/chmod 755 -R /data/share/
四,配置NFS配置nfs的配置文件是 /etc/exports  , vi /etc/exports后,在配置文件中加入一行:/data/share/ *(rw,no_root_squash,no_all_squash,sync)配置可以以ip/端口或者通配為*,ip和端口是客戶端的,意思是允許共享的客戶端,我為了避免更多的坑 , 就通配了*,()中的幾個參數分別是:rw 表示設置目錄可讀寫 。no_root_squash NFS客戶端連接服務端時如果使用的是root的話,那么對服務端分享的目錄來說,也擁有root權限 。no_all_squash 不論NFS客戶端連接服務端時使用什么用戶,對服務端分享的目錄來說都不會擁有匿名用戶權限 。sync 表示數據會同步寫入到內存和硬盤中,相反 rsync 表示數據會先暫存于內存中,而非直接寫入到硬盤中 。如果有多個共享目錄配置,則使用多行,一行一個配置 。保存好配置文件后 , 需要執行 exportfs -r 使配置立即生效.
NAS數據存儲之NFS搭建和使用

文章插圖
五 , 防火墻相關配置配置文件是 /etc/sysconfig/nfs,編輯的話把以下幾個插入,實際使用時,不用配置這幾個,防火墻等等的關閉了或者放開的比較寬,也能正?;ピL 。RQUOTAD_PORT=1001LOCKD_TCPPORT=30001LOCKD_UDPPORT=30002MOUNTD_PORT=1002配置防火墻使用以下幾個命令添加nfs相關端口:firewall-cmd --zone=public --add-port=111/tcp --add-port=111/udp --add-port=2049/tcp --add-port=2049/udp --add-port=1001/tcp --add-port=1001/udp --add-port=1002/tcp --add-port=1002/udp --add-port=30001/tcp --add-port=30002/udp --permanent重新加載防火墻配置:firewall-cmd --reload
六,啟動服務按順序啟動rpcbind和nfs服務,(此順序不能顛倒,否則后續可能會報錯):systemctl start rpcbindsystemctl start nfs(centos7)systemctl start nfs-server(centos8)加入開機啟動:systemctl enable rpcbindsystemctl enable nfs(centos7)systemctl enable nfs-server(centos8)nfs服務啟動后,可以使用命令 rpcinfo -p 查看端口是否生效 。服務器啟動后,我們可以使用 showmount 命令來查看服務端(本機)是否可連接:服務器端執行 showmount -e localhost 
NAS數據存儲之NFS搭建和使用

文章插圖
 客戶機端執行showmount -e 192.168.229.129如果showmount 命令不可用,則可能是客戶端忘記裝nfs-utils了 , 用yum安裝即可 。
七,客戶機執行掛載命令客戶機創建需要掛載的本地目錄,并賦權777mkdir /mnt/sharechmod -R 777 /mnt/sharemount -t nfs 192.168.229.129:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3如果沒有報錯提示的話,執行df -h命令查看,如果顯示文件系統是服務端ip:/目錄  , 容量也對應上了服務器的用量 , 則表示掛載成功了,在本地目錄/mnt/share執行ls -l 可以看到服務的/data/share中的目錄和文件,前提是/data/share在掛載前已經有數據 。再用touch命令創建幾個文件,服務器創建的,客戶機會有,客戶機創建的 , 服務器也有,表示一切順利 。也可能出現掛載顯示成功,數據不同步的情況,后面再詳細分析可能性 。

推薦閱讀