架構(gòu)04nfs存儲(chǔ)服務(wù)器配置

1.什么是NFS?

全稱:network? file? system? 網(wǎng)絡(luò)文件系統(tǒng)

通過網(wǎng)絡(luò)存儲(chǔ)和組織文件的一種方法機(jī)制。

2。為什么要用nfs共享存儲(chǔ)服務(wù)器

前端所有的應(yīng)用服務(wù)器(web服務(wù)器)接收到用戶的圖片,文件,視頻同一放到后邊的nfs共享存儲(chǔ)服務(wù)器上

為什么要共享?所有節(jié)點(diǎn)服務(wù)器都需要將內(nèi)容存放到存儲(chǔ)服務(wù)器上,取得時(shí)候同一取。

3.共享存儲(chǔ)的種類

單一存儲(chǔ)系統(tǒng)就是NFS,適用于中小型企業(yè),相當(dāng)于阿里云服務(wù)的NAS服務(wù),OSS對(duì)象存儲(chǔ)

NFS性能不太高。

大型企業(yè)會(huì)用到FastDFS,Ceph,GlsterFS,Mfs.

大型存儲(chǔ)廠商:EMC、Netapp

4.NFS的工作原理:

因?yàn)镹FS是網(wǎng)絡(luò)文件系統(tǒng)。需要啟動(dòng)NFS服務(wù),而且還要啟動(dòng)很多端口

NFS功能,需要很多很多服務(wù),每個(gè)服務(wù)都有端口,而且經(jīng)常變化

如何讓客戶端找到這些端口呢?就需要一個(gè)RPC服務(wù)(經(jīng)紀(jì)人、中介)



NFS服務(wù):

1.NFS服務(wù)(有很多進(jìn)程和端口)

2.RPC服務(wù)(對(duì)外有固定端口111)

先啟動(dòng)PRC,再啟動(dòng)NFS,NFS自動(dòng)告訴RPC服務(wù)自己的端口,然后客戶需要請(qǐng)求NFS服務(wù),但是沒有NFS的端口,就去找中介PRC,RPC告訴客戶端NFS端口,這時(shí)客戶再拿著NFS的地址去請(qǐng)求NFS服務(wù)。

客戶端請(qǐng)求NFS服務(wù),先找RPC服務(wù)

在服務(wù)器端開搞:

#yum install nfs-utils rpcbind -y(安裝)客戶端需要安裝RPC服務(wù),不用安裝NFS服務(wù)?

#rpm -qa nfs-utils rpcbind(查看是否安裝)

#systemctl start rpcbind.service(啟動(dòng)RPC服務(wù))

#systemctl enable rpcbind.service(設(shè)定開機(jī)自啟動(dòng))

看看有沒有注冊(cè)的端口

[root@nfs01 ~]# rpcinfo -p 127.0.0.1

? program vers proto? port? service

? ? 100000? ? 4? tcp? ? 111? portmapper

? ? 100000? ? 3? tcp? ? 111? portmapper

? ? 100000? ? 2? tcp? ? 111? portmapper

? ? 100000? ? 4? udp? ? 111? portmapper

? ? 100000? ? 3? udp? ? 111? portmapper

? ? 100000? ? 2? udp? ? 111? portmapper

先啟動(dòng)RPC,再啟動(dòng)NFS

#systemctl enable nfs(啟動(dòng)NFS)

#systemctl start nfs(開機(jī)自動(dòng)啟動(dòng)NFS)


編輯etc/exports

#vim /etc/exports

#意思是可以給多個(gè)網(wǎng)段和權(quán)限/data 172.16.1.0/24(rw,sync) 10.0.0.0/24(ro)

#/data 172.16.1.0/24(rw,sync)

查看:

#tail -1 /etc/exports

#mkdir -p /data

#ls? -ld? /data

#grep nfsno /etc/passwd

#chown -R nfsnobody.nfsnobody /data

(設(shè)置/data目錄屬主屬組為nfsnobody)

#grep nfsno /etc/passwd

#ls -ld /data

重啟NFS

#[root@nfs01?~]#?systemctl?reload?nfs?#《==生產(chǎn)場(chǎng)景必須要實(shí)現(xiàn)平滑重啟。

#[root@nfs01?~]#exportfs?-r

上述二者等價(jià),選一個(gè)即可。

#[root@nfs01?~]#showmount?-e?172.16.1.31? 查看這個(gè)IP有沒有共享目錄

Export?list?for?

172.16.1.31:

/data?172.16.1.0/24???#《==看到共享的目錄了

服務(wù)單本地掛載:

#[root@nfs01?~]#?mount?-t?nfs?172.16.1.31:/data?/mnt

? ? ? ? ? ? ? ? ? ? ? ? ? (指定文件系統(tǒng)為nfs 掛載172.16.1.31這臺(tái)主機(jī)上/data目錄 掛載到本地的/mnt目錄下)

#[root@nfs01?~]#?df?-h

文件系統(tǒng)???????????容量??已用??可用?已用%?掛載點(diǎn)

/dev/sda3???????????19G??1.8G???18G???10%?/

devtmpfs???????????476M?????0??476M????0%?/dev

tmpfs??????????????487M?????0??487M????0%?/dev/shm

tmpfs??????????????487M??7.6M??479M????2%?/run

tmpfs??????????????487M?????0??487M????0%?/sys/fs/cgroup

/dev/sda1??????????253M??136M??118M???54%?/boot

tmpfs???????????????98M?????0???98M????0%?/run/user/0

172.16.1.31:/data???19G??1.8G???18G???10%?/mnt

#[root@nfs01?~]#?touch?/mnt/oldboy.txt

#[root@nfs01?~]#?ls?/mnt/

報(bào)錯(cuò):

[root@nfs01 ~]# touch /mnt/oldboy.txt

touch: cannot touch ‘/mnt/oldboy.txt’: Permission denied

這是因?yàn)閽燧d的/data/的目錄的屬組和屬主沒有修改為nfsnobody

做法:

#grep nfsno /etc/passwd

#chown -R nfsnobody.nfsnobody /data

(設(shè)置/data目錄屬主屬組為nfsnobody)

#grep nfsno /etc/passwd

換到web01

1)安裝

yum install nfs-utils rpcbind -y? (安裝)?

rpm -qa nfs-utils rpcbind? (查看是否安裝)

2)啟動(dòng)

systemctl start rpcbind.service(啟動(dòng)RPC服務(wù))

systemctl enable rpcbind.service(設(shè)定開機(jī)自啟動(dòng))

先啟動(dòng)RPC,再啟動(dòng)NFS

systemctl start nfs(啟動(dòng)NFS)

systemctl enable nfs(開機(jī)自啟動(dòng)啟動(dòng)NFS)

[root@web01 ~]# netstat -lntup|grep rpc

udp? ? ? ? 0? ? ? 0 0.0.0.0:775? ? ? ? ? ? 0.0.0.0:*? ? ? ? ? ? ? ? ? ? ? ? ? 11624/rpcbind? ? ?

udp6? ? ? 0? ? ? 0 :::775? ? ? ? ? ? ? ? ? :::*? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 11624/rpcbind? ? ?

[root@web01 ~]# netstat -lntup|grep rpcbind

udp? ? ? ? 0? ? ? 0 0.0.0.0:775? 0.0.0.0:*? ? 11624/rpcbind? ? ?

udp6? ? ? 0? ? ? 0 :::775? ? ? ? :::*? ? ? ? ? 11624/rpcbind? ? ?

[root@web01 ~]# ps -ef|grep rpcbind

rpc? ? ? 11624? ? ? 1? 0 12:17 ?? ? ? ? 00:00:00 /sbin/rpcbind -w

3)查看NFS服務(wù)器提供的共享改那個(gè)目錄

showmount -e 172.16.1.31

如果報(bào)錯(cuò):

nt_create: RPC: Program not registered

? ? ? ? ? ? ? ? ? 程序? ? 沒有? ? ? 注冊(cè)

RPC服務(wù)開啟了,但是NFS沒有告訴RPC服務(wù)端口。

4)掛載測(cè)試

[root@web01 ~]#mount -t nfs 172.16.1.31:/data /mnt

[root@web01 ~]#df -h

文件系統(tǒng)? ? ? ? ? 容量? 已用? 可用 已用% 掛載點(diǎn)

/dev/sda3? ? ? ? ? 19G? 1.8G? 18G? 10% /

devtmpfs? ? ? ? ? 476M? ? 0? 476M? ? 0% /dev

tmpfs? ? ? ? ? ? ? 487M? ? 0? 487M? ? 0% /dev/shm

tmpfs? ? ? ? ? ? ? 487M? 7.6M? 479M? ? 2% /run

tmpfs? ? ? ? ? ? ? 487M? ? 0? 487M? ? 0% /sys/fs/cgroup

/dev/sda1? ? ? ? ? 253M? 136M? 118M? 54% /boot

tmpfs? ? ? ? ? ? ? 98M? ? 0? 98M? ? 0% /run/user/0

172.16.1.31:/data? 19G? 1.8G? 18G? 10% /mnt

[root@web01 ~]#touch /mnt/oldgirl.txt

[root@web01 ~]#ls /mnt/

oldboy.txt? oldgirl.txt


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容