ubuntu安装与配置nfs服务器
轉(zhuǎn)載,
原網(wǎng)址:https://www.linuxidc.com/Linux/2018-03/151384.htm
1.NFS服務(wù)的簡介:
NFS 是 Network File System 的縮寫,是Sun公司于1984開發(fā)的一種分布式文件系統(tǒng)協(xié)議。它的核心功能就是可以通過網(wǎng)絡(luò),讓不同的客戶端,可以彼此訪問共同的文件系統(tǒng) ,來實現(xiàn)文件的共享。像許多其他的協(xié)議,建立在開放的網(wǎng)絡(luò)計算的遠(yuǎn)程過程調(diào)用(RPC)之上。NFS是在RFC中定義的開放標(biāo)準(zhǔn),允許任何人實現(xiàn)該協(xié)議。
NFS 服務(wù)器可以讓客戶端將網(wǎng)絡(luò)遠(yuǎn)程的 NFS 服務(wù)器分享的目錄,直接掛載到本地端的機(jī)器當(dāng)中。本地端的機(jī)器通過直接讀寫掛載的目錄,就可以同步到NFS服務(wù)器之上。
版本更迭
NFS V2
2是NFS最早實現(xiàn)的版本之一,基于UDP協(xié)議實現(xiàn)了一個無狀態(tài)的服務(wù)器版本。僅僅支持32位的系統(tǒng),且不大于2GB的文件。
NFS V3
3的版本在2的基礎(chǔ)之上做了大量的改進(jìn)。支持了大于2GB的文件讀寫,使用了TCP協(xié)議來進(jìn)行數(shù)據(jù)交互,支持了客戶端的異步讀寫來提高文件系統(tǒng)的性能(同時也會產(chǎn)生我們頭疼的一致性問題)
NFS V4
4的版本提高了安全性,通過TCP協(xié)議實現(xiàn)了一個有狀態(tài)的服務(wù)器版本,通過鎖租約的機(jī)制來實現(xiàn)多客戶端的讀寫同步。在4.1版本引入了pNFS,通過類似于一個HDFS架構(gòu)來提供并行的一個分布式文件系統(tǒng)。
2.系統(tǒng)環(huán)境:
系統(tǒng)平臺:Ubuntu 14.04
iptables關(guān)閉: Firewall is disable.(NFS端口使用在默認(rèn)情況下是不固定,所以若配置NFS服務(wù)器需要搭配防火墻使用的話,請配置固定端口)
SELINUX=disabled3.NFS服務(wù)器的安裝:
NFS的安裝只需要安裝rpcbind與nfs-server就可以對外提供服務(wù)了。
rpcbind
NFS 服務(wù)都是通過 RPC 來具體實現(xiàn)的,所以要正常使用NFS服務(wù),需要啟動 rpcbind來實現(xiàn)端口的映射工作 。執(zhí)行如下命令,安裝并啟動rpcbind
nfs-kernel-server
提供nfs服務(wù)器的軟件,提供文件系統(tǒng)的完整功能。這里要提醒一下,NFS服務(wù)器會直接使用到內(nèi)核的模塊,所以內(nèi)核必須要支持 NFS 才行。如果操作系統(tǒng)的版本是自行編譯的內(nèi)核的話,需要注意編譯NFS的內(nèi)核支持。
4.NFS服務(wù)器的配置:
NFS服務(wù)器的主要配置文件就是:/etc/exports。不過這個配置文件不一定會存在,可能需要使用 vim 主動新建這個文件。
/etc/exports文件由以下選項構(gòu)成:
[共享的目錄] [主機(jī)名或IP(參數(shù),參數(shù))]每一行最前面是要分享出來的目錄,目錄可以依照不同的權(quán)限分享給不同的主機(jī)。若權(quán)限參數(shù)不止一個時,則以逗號 (,) 分開。且主機(jī)名與小括號是連在一起的喔!其中參數(shù)是可選的,當(dāng)不指定參數(shù)時,nfs將使用默認(rèn)選項。默認(rèn)的共享選項是 sync,ro,root_squash,no_delay 當(dāng)主機(jī)名或IP地址為空時,則代表共享給任意客戶機(jī)提供服務(wù)。
下面是一些NFS共享的常用參數(shù):
訪問權(quán)限選項
設(shè)置輸出目錄只讀:ro
設(shè)置輸出目錄讀寫:rw
用戶映射選項
all_squash:將遠(yuǎn)程訪問的所有普通用戶及所屬組都映射為匿名用戶或用戶組(nfsnobody);
no_all_squash:與all_squash取反(默認(rèn)設(shè)置);
root_squash:將root用戶及所屬組都映射為匿名用戶或用戶組(默認(rèn)設(shè)置);
no_root_squash:與rootsquash取反;
anonuid=xxx:將遠(yuǎn)程訪問的所有用戶都映射為匿名用戶,并指定該用戶為本地用戶(UID=xxx);
anongid=xxx:將遠(yuǎn)程訪問的所有用戶組都映射為匿名用戶組賬戶,并指定該匿名用戶組賬戶為本地用戶組賬戶(GID=xxx);
其它選項
secure:限制客戶端只能從小于1024的tcp/ip端口連接nfs服務(wù)器(默認(rèn)設(shè)置);
insecure:允許客戶端從大于1024的tcp/ip端口連接服務(wù)器;
sync:將數(shù)據(jù)同步寫入內(nèi)存緩沖區(qū)與磁盤中,效率低,但可以保證數(shù)據(jù)的一致性;
async:將數(shù)據(jù)先保存在內(nèi)存緩沖區(qū)中,必要時才寫入磁盤;
wdelay:檢查是否有相關(guān)的寫操作,如果有則將這些寫操作一起執(zhí)行,這樣可以提高效率(默認(rèn)設(shè)置);
no_wdelay:若有寫操作則立即執(zhí)行,應(yīng)與sync配合使用;
subtree:若輸出目錄是一個子目錄,則nfs服務(wù)器將檢查其父目錄的權(quán)限(默認(rèn)設(shè)置);
no_subtree:即使輸出目錄是一個子目錄,nfs服務(wù)器也不檢查其父目錄的權(quán)限,這樣可以提高效率;
這里我們使用了NFS v3的配置,如下圖所示:
5.NFS服務(wù)器的啟動:
配置完/etc/exports之后,接下來就可以啟動NFS服務(wù)器了。
為了使NFS服務(wù)器能正常工作,需要啟動rpcbind和nfs-kernel-server兩個服務(wù),并且rpcbind一定要先于nfs-kernel-server啟動。
sudo service rpcbind startsudo service nfs-kernel-server start若要開機(jī)自啟動nfs服務(wù),可以通過sysv-rc-conf配置自啟動服務(wù)。
sudo sysv-rc-conf --level 35 rpcbind onsudo sysv-rc-conf --level 35 nfs-kernel-server on6.NFS客戶端的掛載:
客戶端的掛載很簡單,先建立一個掛載目錄
sudo mkdir /mnt/nfssudo mount -t nfs 192.168.12:/tmp /mnt/nfs之后客戶端對應(yīng)的文件目錄便掛載上對應(yīng)的文件系統(tǒng)了。
7、啟動自動掛載NFS文件系統(tǒng):
客戶端可以通過命令配置開機(jī)自啟動掛載NFS的文件系統(tǒng)。
格式:
<server>:</remote/export> </local/directory> nfs < options> 0 0 將對應(yīng)的命令 mount -t nfs 192.168.12:/tmp /mnt/nfs 添加至/etc/rc.d/local,不要嘗試在直接在/etc/fstab/里掛載原因分析:
在Linux內(nèi)核啟動的流程中,網(wǎng)絡(luò)的啟動是在本機(jī)文件系統(tǒng)掛載之后,所以直接利用 /etc/fstab 嘗試掛載 NFS 時,系統(tǒng)由于尚未啟動網(wǎng)絡(luò),是無法掛載成功的。
總結(jié)
以上是生活随笔為你收集整理的ubuntu安装与配置nfs服务器的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 作者:高富平(1963-),男,博士,华
- 下一篇: 2017第四届中国国际大数据大会成功召开