RHCE: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 注册。

二、NFS配置

服务端:(192.168.117.128)

#安装 rpcbind 软件包、安装 nfs-utils 软件包:
[root@server ~]# yum install rpcbind -y
[root@server ~]# yum install nfs-utils  -y
/etc/exports 主配置文件(文件不一定存在)
/usr/sbin/showmount 该命令主要用在client端。这个命令可以查看NFS共享出来的目录资源

[root@server ~]# mkdir /data
 
#编辑配置 NFS 共享目录及其权限:
[root@server ~]# vim /etc/exports
 /data  192.168.168.140(rw)
#共享目录 主机名(权限)
#可以使用完整的IP或者是网络号,例如172.24.8.128或172.24.8.0/24或者
172.24.8.128/255.255.255.0;也可以使用*表示所有主机

#修改 /data 目录的权限,添加其他用户(others)写权限:
[root@server ~]# chmod o+w /data/
[root@server ~]# systemctl disable firewalld --now
[root@server ~]# setenforce 0
[root@server ~]# getenforce
Permissive

# 启动程序
[root@server ~]# systemctl start rpcbind
[root@server ~]# systemctl start nfs-server

#showmount 命令查询 NFS 服务器 192.168.117.128 上导出的文件系统列表:
[root@server ~]# showmount -e 192.168.117.128
Export list for 192.168.117.128:
/data 192.168.117.133

客户端:(192.168.117.133)

#安装 rpcbind 软件包、安装 nfs-utils 软件包:
[root@client ~]# yum install rpcbind -y
[root@client ~]# yum install nfs-utils -y
[root@client ~]# systemctl disable firewalld --now
[root@client ~]# setenforce 0
[root@client ~]# getenforce
Permissive
 
#showmount 命令查询 NFS 服务器 192.168.117.128 上导出的文件系统列表:
[root@client ~]# showmount -e 192.168.117.128
Export list for 192.168.117.128:
/data 192.168.117.133
#递归创建目录
[root@client ~]# mkdir -p /nfsclient/client-data/
 
#将 NFS 服务器 192.168.117.128 上的 /data 目录挂载到本地的 /nfsclient/client-data/ 目录:
[root@client ~]#  mount 192.168.117.128:/data /nfsclient/client-data
[root@client ~]# df -h
文件系统                    大小  已用  可用 已用% 挂载点
devtmpfs                    4.0M     0  4.0M    0% /dev
tmpfs                       708M     0  708M    0% /dev/shm
tmpfs                       283M  5.5M  278M    2% /run
tmpfs                       4.0M     0  4.0M    0% /sys/fs/cgroup
/dev/mapper/openeuler-root   27G  1.6G   24G    7% /
tmpfs                       708M     0  708M    0% /tmp
/dev/sda1                   974M  179M  728M   20% /boot
192.168.117.128:/data        17G  5.5G   11G   34% /nfsclient/client-data

权限相关参数可以写多个,多个参数之间用逗号隔开,具体相关参数说明如下:

排错:

配置完 nfs 环境后使用 showmount -e 命令报错
rpc 程序没有注册成功

解决:
# 如果nfs报错
systemctl restart nfs-server.service
systemctl restart rpcbind

#或者
[root@master01 ~]# systemctl enable --now nfs-server rpcbind

三、配置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 install autofs -y
[root@client ~]# grep suibian /etc/auto.master
/client /etc/auto.suibian
#本地端目录 具体挂载配置文件
[root@client ~]# cat /etc/auto.suibian
upload 192.168.168.128:/nfs/upload
#本地端子目录 挂载参数 服务器:服务器对应目录
[root@client ~]# systemctl restart autofs
#触发自动挂载
[root@client ~]# cd /client
[root@client ~]# cd upload

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值