NFS网络文件系统

目录

简介

案例

配置autofs自动挂载

 客户端配置autofs 


简介

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

案例

软件下载

[root@localhost ~]# yum install rpcbind

[root@localhost ~]# yum install nfs-utils

[root@localhost ~]# systemctl stop firewalld

[root@localhost ~]# setenforce 0

#服务端(192.168.168.135)

[root@server ~]# systemctl start nfs-server

[root@server ~]# mkdir  /public

[root@server ~]# touch /public/{1..10}

[root@server public]# vim /etc/exports    --打开nfs配置文件

#共享目录  允许访问主机的IP *(权限,访问参数)

/test *(rw)    --可读写,*表示所有IP地址

/public *(rw)

        #/public *(ro,no_root_squash)

        #/public *(ro,all_squash)

        #/test  *(rw,all_sqush,anonuid=1111,anongid=1111)   ---允许所有用户作为用户所有者和所有组,并可以指定uid与gid值

#共享目录  主机名(权限)

#可以使用完整的IP或者是网络号,例如172.24.8.128或172.24.8.0/24或者172.24.8.128/255.255.255.0;也可以使用*表示所有主机

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

[root@server public]# exportfs -r     ---加载配置文件

客户端Client

[root@client /]# yum install nfs-utils -y

[root@client /]# mkdir /t

[root@client /]# mount -o ro 192.168.221.135:/test  /t

-o ro:是选项,指定挂载的模式为只读(ro 表示 read-only)。

[root@client /]# mount -o remount,rw /t   

------------------------------------------

[root@client /]# showmount -e 192.168.221.135    --查看共享的网络文件系统是否成功

注:client 管理员root访问nfs文件系统默认做了用户映射root --nobody(65534),这是因为服务端主机为了安全问题不能直接授予root用户。

[root@client /] #mount -o remount,ro /t    ---已挂载,将文件系统修改为只读

[root@client /] #mount -o ro 192.168.10.130:/public  /t    --还未挂载,挂载出来的文件只读

注:

一个挂载点目录可以同时挂载多个文件系统,通过挂载点查看是最后一次挂载文件系统中的数据文件。

查看网络文件系统占用量

配置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

[root@client /]# vim /etc/auto.master     ---进入主配置文件修改

[root@client ~]# vim /etc/auto.nfs   --创建子配置文件

挂载点          访问目录的文件系统类型以及是否可写或者同步       路径

[root@client /]# showmount -e 192.168.221.135    --查看是否可以挂载

[root@client /]# systemctl restart autofs.service   --重启自动挂载服务

这个时候发现在根目录下多了一个nfs目录

[root@client /]# cd nfs/test    --访问并查看此目录

访问触动挂载即自动挂载

  • 21
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

妍妍的宝贝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值