NFS服務(wù)會經(jīng)常用到,它用于在網(wǎng)絡(luò)上共享存儲。舉例來說,假如有3臺機(jī)器A、B和C,它們需要訪問同一個目錄,且目錄中都是圖片。傳統(tǒng)的做法是把這些圖片分別放到A、B、C中,但若使用NFS,只需要把圖片放到A上,然后A共享給B和C即可。訪問B和C時,是通過網(wǎng)絡(luò)的方式去訪問A上的那個目錄的。
18.1服務(wù)端配置NFS
在Rocky8上使用NFS服務(wù)需要安裝兩個包(nfs-utils和rpcbind),不過當(dāng)使用yum工具安裝nfs-utils時會一并安裝rpcbind,如下所示:
# yum install -y nfs-utils早期的CentOS版本是需要安裝portmap包的,從CentOS 6開始,就改為安裝rpcbind包了。配置NFS比較簡單,只需要編輯配置文件/etc/exports。下面阿銘就先創(chuàng)建一個簡單的NFS服務(wù)器。 首先修改配置文件(默認(rèn)該文件為空),如下所示:
# vim /etc/exports //寫入如下內(nèi)容: /home/nfstestdir 192.168.72.0/24(rw,sync,all_squash,anonuid=1000,anongid=1000)這個配置文件就一行,共分為三部分。第一部分是本地要共享出去的目錄,第二部分是允許訪問的主機(jī)(可以是一個IP,也可以是一個IP段),第三部分就是小括號里面的一些權(quán)限選項。關(guān)于第三部分,阿銘簡單介紹一下。
rw:表示讀/寫。
ro:表示只讀。
sync:同步模式,表示內(nèi)存中的數(shù)據(jù)實時寫入磁盤。
async:非同步模式,表示把內(nèi)存中的數(shù)據(jù)定期寫入磁盤。
no_root_squash:加上這個選項后,root用戶就會對共享的目錄擁有至高的權(quán)限控制,就像是對本機(jī)的目錄操作一樣。但這樣安全性降低。
root_squash:與no_root_squash選項對應(yīng),表示root用戶對共享目錄的權(quán)限不高,只有普通用戶的權(quán)限,即限制了root。
all_squash:表示不管使用NFS的用戶是誰,其身份都會被限定為一個指定的普通用戶身份。
anonuid/anongid:要和root_squash以及all_squash選項一同使用,用于指定使用NFS的用戶被限定后的uid和gid,但前提是本機(jī)的/etc/passwd中存在相應(yīng)的uid和gid。
介紹了NFS的相關(guān)權(quán)限選項后,阿銘再來分析一下剛剛配置的/etc/exports文件。假設(shè)要共享的目錄為/home/nfstestdir,信任的主機(jī)為192.168.72.0/24這個網(wǎng)段,權(quán)限為讀/寫,同步模式,限定所有使用者,并且限定的uid和gid都為1000。 編輯好配置文件后創(chuàng)建相關(guān)目錄并啟動NFS服務(wù),如下所示:
# mkdir /home/nfstestdir # systemctl start rpcbind # systemctl start nfs-server # systemctl enable rpcbind # systemctl enable nfs-server在啟動NFS服務(wù)之前,需要先啟動rpcbind服務(wù)(CentOS的老版本中為portmap)。
18.2客戶端掛載NFS
做本節(jié)課實驗最好是打開另外一臺虛擬機(jī),如果你的計算機(jī)資源吃緊,也可以在一臺機(jī)器上操作,即客戶端、服務(wù)端為一臺機(jī)器。阿銘的兩臺虛擬機(jī)IP地址分別為192.168.72.128和192.168.72.129,其中提供NFS服務(wù)的是192.168.72.128。在客戶端掛載NFS之前,我們需要先查看服務(wù)端共享了哪些目錄??蛻舳耍?2.129)安裝nfs-utils包后,可以使用showmount命令查看,如下所示:
# showmount -e 192.168.72.128 Export list for 192.168.72.128: /home/nfstestdir 192.168.72.0/24使用命令showmount -e IP就可以查看NFS的共享情況,從上例我們可以看到192.168.72.128的共享目錄為/home/nfstestdir,信任主機(jī)為192.168.72.0/24這個網(wǎng)段。 然后在客戶端上(72.129)掛載NFS,如下所示:
# mount -t nfs 192.168.72.128:/home/nfstestdir /mnt/ # df -h 文件系統(tǒng) 容量 已用 可用 已用% 掛載點 devtmpfs 888M 0 888M 0% /dev tmpfs 904M 0 904M 0% /dev/shm tmpfs 904M 8.7M 895M 1% /run tmpfs 904M 0 904M 0% /sys/fs/cgroup /dev/sda3 28G 6.2G 22G 23% / /dev/sda1 190M 127M 49M 73% /boot tmpfs 181M 0 181M 0% /run/user/0 192.168.72.128:/home/nfstestdir 28G 6.2G 22G 23% /mnt使用命令df -h可以看到增加了一個/mnt分區(qū),它就是NFS共享的目錄了。進(jìn)入到/mnt/目錄下,并創(chuàng)建測試文件:
# cd /mnt/ # touch aminglinux.txt touch: 無法創(chuàng)建"aminglinux.txt": 權(quán)限不夠這是因為在服務(wù)端(72.128)上創(chuàng)建的/home/nfstestdir目錄權(quán)限不合適,掛載后相當(dāng)于被限制為uid為1000的用戶,解決該問題需要在服務(wù)端(72.128)上修改/home/nfstestdir目錄權(quán)限:
# chmod 777 /home/nfstestdir/然后再到客戶端上(188.129)創(chuàng)建測試文件:
# cd /mnt/ # touch aminglinux.txt # ls -l 總用量 0 -rw-r--r-- 1 mysql mysql 0 7月 1 22:16 aminglinux.txt # id aming uid=1000(mysql) gid=1000(mysql) 組=1000(mysql)可以看到創(chuàng)建的新文件aminglinux.txt所有者和所屬組為mysql,其uid和gid都為1000。
18.3命令exportfs
exportfs命令的常用選項為-a、-r、-u和-v,各選項的含義如下。
-a:表示全部掛載或者卸載。
-r:表示重新掛載。
-u:表示卸載某一個目錄。
-v:表示顯示共享的目錄。
當(dāng)改變/etc/exports配置文件后,使用exportfs命令掛載不需要重啟NFS服務(wù)。接下來阿銘做一個試驗,首先修改服務(wù)端(72.128)的配置文件,如下所示:
# vim /etc/exports #增加一行: /tmp/ 192.168.72.0/24(rw,sync,no_root_squash)然后在服務(wù)端(72.128)上執(zhí)行如下命令:
# exportfs -arv exporting 192.168.72.0/24:/tmp exporting 192.168.72.0/24:/home/nfstestdir在上一節(jié)用到了mount命令。其實用mount命令來掛載NFS服務(wù)是有講究的,它要用-t nfs來指定掛載的類型為nfs。另外在掛載NFS服務(wù)時,常用-o nolock選項(即不加鎖)。例如在客戶端(72.129)上執(zhí)行如下命令:
# mkdir /aminglinux # mount -t nfs -o nolock 192.168.72.128:/tmp/ /aminglinux/你還可以把要掛載的NFS目錄寫到客戶端上的/etc/fstab文件中,掛載時只需要執(zhí)行mount -a命令。例如在/etc/fstab文件里增加一行,如下所示:
192.168.72.128:/tmp/ /aminglinux nfs defaults,nolock 0 0由于剛剛已掛載了NFS,需要先卸載,執(zhí)行如下命令:
# umount /aminglinux然后重新掛載,執(zhí)行如下命令:
# mount -a這樣操作的好處是以后開機(jī)會自動掛載NFS。剛剛掛載的/aminglinux/目錄在服務(wù)端設(shè)置為了no_root_squash,它并不會限制root用戶,也就是說使用root用戶創(chuàng)建文件時,跟在客戶端本機(jī)上創(chuàng)建的一樣。下面是實驗過程:
# cd /aminglinux/ # touch 1.txt # ls -l 1.txt -rw-r--r-- 1 root root 1113 7月 1 22:19 1.txt可以看到1.txt的所有者和所屬組全部為root。
審核編輯:劉清
-
虛擬機(jī)
+關(guān)注
關(guān)注
1文章
918瀏覽量
28232 -
NFS
+關(guān)注
關(guān)注
1文章
53瀏覽量
26118 -
UUID
+關(guān)注
關(guān)注
0文章
22瀏覽量
8138
原文標(biāo)題:一篇文章學(xué)會NFS
文章出處:【微信號:aming_linux,微信公眾號:阿銘linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論