1.什么是NFS?
全稱:network? file? system? 網絡文件系統
通過網絡存儲和組織文件的一種方法機制。
2。為什么要用nfs共享存儲服務器
前端所有的應用服務器(web服務器)接收到用戶的圖片,文件,視頻同一放到后邊的nfs共享存儲服務器上
為什么要共享?所有節點服務器都需要將內容存放到存儲服務器上,取得時候同一取。
3.共享存儲的種類
單一存儲系統就是NFS,適用于中小型企業,相當于阿里云服務的NAS服務,OSS對象存儲
NFS性能不太高。
大型企業會用到FastDFS,Ceph,GlsterFS,Mfs.
大型存儲廠商:EMC、Netapp
4.NFS的工作原理:
因為NFS是網絡文件系統。需要啟動NFS服務,而且還要啟動很多端口
NFS功能,需要很多很多服務,每個服務都有端口,而且經常變化
如何讓客戶端找到這些端口呢?就需要一個RPC服務(經紀人、中介)
NFS服務:
1.NFS服務(有很多進程和端口)
2.RPC服務(對外有固定端口111)
先啟動PRC,再啟動NFS,NFS自動告訴RPC服務自己的端口,然后客戶需要請求NFS服務,但是沒有NFS的端口,就去找中介PRC,RPC告訴客戶端NFS端口,這時客戶再拿著NFS的地址去請求NFS服務。
客戶端請求NFS服務,先找RPC服務
在服務器端開搞:
#yum install nfs-utils rpcbind -y(安裝)客戶端需要安裝RPC服務,不用安裝NFS服務?
#rpm -qa nfs-utils rpcbind(查看是否安裝)
#systemctl start rpcbind.service(啟動RPC服務)
#systemctl enable rpcbind.service(設定開機自啟動)
看看有沒有注冊的端口
[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
先啟動RPC,再啟動NFS
#systemctl enable nfs(啟動NFS)
#systemctl start nfs(開機自動啟動NFS)
編輯etc/exports
#vim /etc/exports
#意思是可以給多個網段和權限/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
(設置/data目錄屬主屬組為nfsnobody)
#grep nfsno /etc/passwd
#ls -ld /data
重啟NFS
#[root@nfs01?~]#?systemctl?reload?nfs?#《==生產場景必須要實現平滑重啟。
#[root@nfs01?~]#exportfs?-r
上述二者等價,選一個即可。
#[root@nfs01?~]#showmount?-e?172.16.1.31? 查看這個IP有沒有共享目錄
Export?list?for?
172.16.1.31:
/data?172.16.1.0/24???#《==看到共享的目錄了
服務單本地掛載:
#[root@nfs01?~]#?mount?-t?nfs?172.16.1.31:/data?/mnt
? ? ? ? ? ? ? ? ? ? ? ? ? (指定文件系統為nfs 掛載172.16.1.31這臺主機上/data目錄 掛載到本地的/mnt目錄下)
#[root@nfs01?~]#?df?-h
文件系統???????????容量??已用??可用?已用%?掛載點
/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/
報錯:
[root@nfs01 ~]# touch /mnt/oldboy.txt
touch: cannot touch ‘/mnt/oldboy.txt’: Permission denied
這是因為掛載的/data/的目錄的屬組和屬主沒有修改為nfsnobody
做法:
#grep nfsno /etc/passwd
#chown -R nfsnobody.nfsnobody /data
(設置/data目錄屬主屬組為nfsnobody)
#grep nfsno /etc/passwd
換到web01
1)安裝
yum install nfs-utils rpcbind -y? (安裝)?
rpm -qa nfs-utils rpcbind? (查看是否安裝)
2)啟動
systemctl start rpcbind.service(啟動RPC服務)
systemctl enable rpcbind.service(設定開機自啟動)
先啟動RPC,再啟動NFS
systemctl start nfs(啟動NFS)
systemctl enable nfs(開機自啟動啟動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服務器提供的共享改那個目錄
showmount -e 172.16.1.31
如果報錯:
nt_create: RPC: Program not registered
? ? ? ? ? ? ? ? ? 程序? ? 沒有? ? ? 注冊
RPC服務開啟了,但是NFS沒有告訴RPC服務端口。
4)掛載測試
[root@web01 ~]#mount -t nfs 172.16.1.31:/data /mnt
[root@web01 ~]#df -h
文件系統? ? ? ? ? 容量? 已用? 可用 已用% 掛載點
/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