nfs服务器
1.nfs概述
NFS(Network File System,网络文件系统)是FreeBSD支持的文件系统中的一种,它允许网络中的计算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系列操作系统上使用。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。
NFS服务器可以让PC将网络中的NFS服务器共享的目录挂载到本地端的文件系统中,而在本地端的系统中看来,那个远程主机的目录就好像是自己的一个磁盘分区一样。
由于NFS支持的功能比较多,而不同的功能都会使用不同的程序来启动,每启动一个功能就会启用一些端口来传输数据,因此NFS的功能所对应的端口并不固定,而是随机取用一些未被使用的小于1024的端口用于传输。但如此一来就会产生客户端连接服务器的问题,因为客户端需要知道服务器端的相关端口才能够连接。
此时就需要RPC(Remote Procedure Call,远程过程调用)的服务。由于当服务器在启动NFS时会随机选取数个端口号,并主动向RPC注册,所以RPC知道每个NFS功能所对应的端口号,RPC将端口号通知给客户端,让客户端可以连接到正确的端口上去。RPC采用固定端口号port 111来监听客户端的需求并向客户端响应正确的端口号。
(注:在启动NFS之前,要先启动RPC,否则NFS会无法向RPC注册。另外,RPC若重新启动,原来注册的数据会消失不见,因此RPC重启后,它管理的所有服务都需要重新启动以重新向RPC注册。)
2.nfs配置
[root@localhost ~]# yum install rpcbind
[root@localhost ~]# yum install nfs-utils
#服务端(192.168.190.131)
[root@localhosts data]# mkdir /data
[root@localhosts data]# cat /etc/exports
/data 192.168.190.133(rw)
[root@localhosts data]# chmod o+w /data/
[root@localhosts data]# systemctl disable firewalld --now
[root@localhosts data]# getenforce
Enforcing
[root@localhosts data]# setenforce 0
[root@localhosts data]# systemctl restart nfs-server
[root@localhosts data]# showmount -e 192.168.190.131
Export list for 192.168.190.131:
/data 192.168.190.133
#客户端(192.168.190.133)
[root@client ~]# showmount -e 192.168.190.131
Export list for 192.168.190.131:
/data 192.168.190.133
[root@client ~]# mkdir -p /nfsclient/client-data/
[root@client ~]# mount 192.168.190.131:/data /nfsclient/client-data/
[root@client ~]# df -h