一、简介
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
注册。
二、nfs配置
[root@localhost ~]# yum install rpcbind
[root@localhost ~]# yum install nfs-utils
/etc/exports 主配置文件(文件不一定存在)
/usr/sbin/showmount 该命令主要用在client端。这个命令可以查看NFS共享出来的目录资源
1.服务端(192.168.36.136)
[root@service ~]# mkdir /data
[root@service ~]# cat /etc/exports
/data 192.168.36.30(rw)
[root@service ~]# vim /etc/exports
[root@service ~]# chmod o+w /data
[root@service ~]# systemctl disable firewalld --now
[root@service ~]# getenforce
Permissive
[root@service ~]# systemctl restart nfs-server
[root@service ~]# showmount -e 192.168.36.136
Export list for 192.168.36.136:
/data 192.168.36.30
2.客户端
[root@client ~]# showmount -e 192.168.36.136
Export list for 192.168.36.136:
/data 192.168.36.30
[root@client ~]# mount 192.168.36.136:/data /nfsclient/client-data/
[root@client ~]# df -h
文件系统 容量 已用 可用 已用% 挂载点
devtmpfs 4.0M 0 4.0M 0% /dev
tmpfs 872M 0 872M 0% /dev/shm
tmpfs 349M 9.8M 339M 3% /run
/dev/mapper/rhel-root 37G 5.8G 31G 16% /
/dev/nvme0n1p2 1014M 276M 739M 28% /boot
/dev/nvme0n1p1 599M 7.0M 592M 2% /boot/efi
tmpfs 175M 104K 175M 1% /run/user/0
/dev/sr0 8.5G 8.5G 0 100% /run/media/root/RHEL-9-1-0-BaseOS-x86_64
192.168.36.136:/data 17G 5.6G 11G 34% /nfsclient/client-data
三、配置autofs自动挂载
在一般
NFS
文件系统的使用过程中,如果客户端要使用服务端所提供的文件系统,可以在
/etc/rc.d/rc.local
中设置开机时自动挂载(
/etc/rc.d/rc.local
文件中写入的命令,在每次启动系统用户 登录之前都会执行一次);
也可以在登录系统后手动利用
mount
来挂载。
由于网络的问题,
NFS
服务器与客户端的连接不会一直存在,当我们挂载了
NFS
服务器之后,任何一方 脱机都可能造成另外一方等待超时。为了解决这样的问题,就出现了下面的想法:
当客户端在有使用NFS
文件系统的需求时才让系统自动挂载。
当
NFS
文件系统使用完毕后,让
NFS
自动卸载。
于是就产生了
autofs
这个服务。
autofs
这个服务是在客户端的上面,它会持续的检测某个指定的目录,并预先设置当使用到该目录的某 个子目录时,将会取得来自服务器端的NFS
文件系统资源,并进行自动挂载的操作。
#客户端配置autofs
[root@client ~]# yum :wqinstall autofs -y
[root@client ~]# grep suibian /etc/auto.master
/client /etc/auto.suibian
#本地端目录 具体挂载配置文件
[root@client ~]# cat /etc/auto.suibian
upload 192.168.36.136:/nfs/upload
#本地端子目录 挂载参数 服务器:服务器对应目录
[root@client ~]# systemctl restart autofs
#触发自动挂载
[root@client ~]# cd /client
[root@client ~]# cd /upload