目录

NFS服务器简介

 NFS的使用

【手工挂载】

客户端使用autofs自动挂载



NFS服务器简介

配置文件置顶:

主配置文件:vim /etc/exports【文件可能不存在、正常的】

        NFS(Network File System,网络文件系统)是FreeBSD支持的文件系统中的一种,它允许网络中的计算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系列操作系统上使用。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。

目录挂载到本地端的文件系统中,而在本地端的系统中看来,那个远程主机的目录就好像是自己的一个磁盘分区一样。

         由于NFS支持的功能比较多,而不同的功能都会使用不同的程序来启动,每启动一个功能就会启用一些端口来传输数据,因此NFS的功能所对应的端口并不固定,而是随机取用一些未被使用的小于1024的端口用于传输。但如此一来就会产生客户端连接服务器的问题,因为客户端需要知道服务器端的相关端口才能够连接。

         此时就需要RPC(Remote Procedure Call,远程过程调用)的服务。由于当服务器在启动NFS时会随机选取数个端口号,并主动向RPC注册,所以RPC知道每个NFS功能所对应的端口号,RPC将端口号通知给客户端,让客户端可以连接到正确的端口上去。RPC采用固定端口号port 111来监听客户端的需求并向客户端响应正确的端口号。【简而言之,就是nfs启动的时候随便选几个端口,我们要在它启动前启动rpc,它启动的端口就会去注册,我们就方便操作了】

         注:在启动NFS之前,要先启动RPC,否则NFS会无法向RPC注册。另外,RPC若重新启动,原来注册的数据会消失不见,因此RPC重启后,它管理的所有服务都需要重新启动以重新向RPC注册。

从NFS目录拷贝大文件到本地其他目录 nfs server用到的文件和目录_linux

 NFS的使用

RPC主程序:rpcbind

NFS主程序:nfs-utils

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

【记住开启服务顺序】

rpcbind 》nfs-server.service
        [root@localhost etc]# systemctl restart rpcbind
        [root@localhost etc]# systemctl restart nfs-server.service

简单的NFS配置:

两台机器:一台作为NFS服务器,一台作为NFS客户端

【手工挂载】

NFS服务器的配置:

        安装rpcbind, nfs-utils

        启动:先启动rpcbind, 然后再启动nfs-server

        vim /etc/exports

        # share1必须提前存在,且将目录权限修改为777【配置过一次权限不够的共享失败了】

        /share1 *(rw)

        # 重新加载资源【不用重启加载服务,刷新资源就行】

        exportfs -r

 

【关联】exportfs的选项

  • -a全部挂载或卸载/etc/exports中的内容
  • -r重新读取/etc/exports中的信息,并同步更新/etc/exports,/var/lib/nfs/xtab
  • -u卸载单一目录(和-a一起使用为卸载所有/etc/exports文件中的目录)
  • -v在export的时候,将详细的信息输出到屏幕上

客户端:

        安装rpcbind, nfs-utils

        启动rpcbind

        showmount -e nfs服务器的IP

        mount nfs服务器的IP:/share1 /data1

        去操作/data1目录即可

  • /etc/exports主配置文件(文件不一定存在)
  • /usr/sbin/exportfs 维护NFS共享资源的命令,可以使用该命令重新共享/etc/exports更新的目录资源、将NFS server共享的目录卸载或重新共享等
  • /var/lib/nfs/*tab                 在NFS服务器中,日志文件都放置到/var/lib/nfs目录中,在该目录下有两个比较重要的日志文件,一个是etab,主要记录了NFS所共享出来的目录的完整权限设置值;另一个是xtab,记录了曾经链接到此NFS服务器的相关客户端数据。
  • /usr/sbin/showmount 该命令主要用在client端。这个命令可以查看NFS共享出来的目录资源

【/etc/exports配置文件的语法与参数】

        哪些目录可以被哪些主机使用

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

        | -------- | -------------- |

        该文件内,每一行最前面表示要共享的目录。

        例、/share1 * (ew)         

        主机名的设置方式:

         可以使用完整的IP或者是网络号,例如172.24.8.128或172.24.8.0/24或者        、172.24.8.128/255.255.255.0

         可以使用主机名,但是主机名必须要在/etc/hosts内,或者可以使用DNS域名解析解析出对应的IP地址。可以用‘  *。        

         权限需要写在括号内,且括号是紧接着主机名的。权限相关参数可以写多个,多个参数之间用逗号隔开,具体相关参数说明如下:



参数值

说明

rw/ro

该目录共享的权限是可读写还是只读,但最终能否读写,还是与文件系统的rwx有关

sync/async

sync代表数据会同步写入到内存与硬盘中,async则代表数据会先暂存于内存当中,而非直接写入硬盘

no_root_squash/root_squash

若客户端在共享目录里创建的文件的所属者和所属组是root用户和root组,那么显示文件的属主和属组时有以下两种情况:norootsquash表示,文件的所属者和所属组是root用户和root组;root_squash表示将root用户和组映射为匿名用户和组(默认设置)。/share1 * (ew,noroot_squash)能看到root了不是nobody了

all_squash/no_all_squash

allsquash:客户端所有用户创建文件时,客户端会将文件的用户和组映射为匿名用户和组noall_squash:客户端普通用户创建的文件的UID和GID是多少,服务端就显示为多少(默认设置)

anonuid=anongid=

将文件的用户和组映射为指定的UID和GID,若不指定默认为65534(nfsnobody)



客户端使用autofs自动挂载

        在一般NFS文件系统的使用过程中,如果客户端要使用服务端所提供的文件系统,可以在/etc/rc.d/rc.local中设置开机时自动挂载(/etc/rc.d/rc.local文件中写入的命令,在每次启动系统用户登录之前都会执行一次);也可以在登录系统后手动利用mount来挂载。

        由于网络的问题,NFS服务器与客户端的连接不会一直存在,当我们挂载了NFS服务器之后,任何一方脱机都可能造成另外一方等待超时。为了解决这样的问题,就出现了下面的想法:

         1、当客户端在有使用NFS文件系统的需求时才让系统自动挂载。

         2、当NFS文件系统使用完毕后,让NFS自动卸载。

        于是就产生了autofs这个服务。

         autofs这个服务是在客户端的上面,它会持续的检测某个指定的目录,并预先设置当使用到该目录的某个子目录时,将会取得来自服务器端的NFS文件系统资源,并进行自动挂载的操作。

【自动挂载配置环节】

第一步、vim  /etc/auto.master

/data2 /etc/auto.nfs【解析,自动挂载到/data2这个目录上,下面那一句是系统自带的】


从NFS目录拷贝大文件到本地其他目录 nfs server用到的文件和目录_linux_02

 

| 本地端子目录 | [-挂载参数] | 服务器所提供的目录 |

| ------------ | ----------- | ------------------ |

本地端子目录表示你要将服务器所提供的目录挂载在客户端的/nfs的目录名

挂载参数👇【可不写】

参数

参数功能

fg / bg

当执行挂载时,该挂载行为会在前台(fg)还是后台(bg)执行,若在前台执行,则mount会持续尝试挂载,直到成功或time out为止;若为后台执行,则mount会在后台持续多次进行mount,而不会影响到前台的程序运行。

soft / hard

hard表示当两者之间的任何一台主机脱机,则RPC会持续地呼叫,直到对方恢复连接为止。如果是soft的话,那RPC会在time out后重复呼叫,而非持续呼叫

intr

当使用上面提到的hard方式挂载时,若加上intr这个参数,则当RPC持续呼叫时,该次的呼叫是可以被中断的

rsize / wsize

读出(rsize)与写入(wsize)的区块大小。这个设置值可以影响客户端与服务器端传输数据的缓冲记忆容量

第二步、配置/etc/auto.nfs

sudir 192.168.174.128:/share2  【将共享目录放在这然后把NFS服务器IP也写上】

然后重启autofs服务

查看挂载信息mount |grep /data2

从NFS目录拷贝大文件到本地其他目录 nfs server用到的文件和目录_服务器_03

     【这就是已经挂载成功了】 

现在进去客户端的data2目录看不到共享时编辑的文件,因为忽略了之前的一句话

从NFS目录拷贝大文件到本地其他目录 nfs server用到的文件和目录_网络_04

在NFS服务端上cd /data2/subdir这个目录(其实没有这个目录,就是个假目录而已)让服务知道你的需求,就可以了

之后就随便操作共享目录了

退出目录就代表你要退出服务了,需要等待一定的时间才会卸载,这个时间在/etc/autofs.conf >> dismount_interval = 300有需要的话自己改