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 /etc/exports 主配置文件(文件不一定存在) 编辑/etc/exports文件 例: /data 192 .168.58.5(rw) # 共享目录 主机名(权限) /usr/sbin/showmount 该命令主要用在 client 端。这个命令可以查看 NFS 共享出来的目录资源 # 服务端 (192.168.144.131) \[root@server data\] # mkdir /data 创建共享目录 \[root@server data\] # vim /etc/exports 编辑文件 /data 192.168.144.132(rw) \[root@server data\] # chmod o+w /data/ \[root@server data\] # systemctl disable firewalld --now \[root@server data\] # getenforce Enforcing \[root@server data\] # setenforce 0 \[root@server data\] # systemctl restart nfs-server \[root@server data\] # showmount -e 192.168.144.131 Export list for 192.168.144.131: /data 192.168.144.132 > 说明: > > 说明 > > rw , ro: > > 该目录共享的权限是可读写还是只读,但最终能否读写,还是与 文件系统的 rwx有关 > > sync , async: > > sync 代表数据会同步写入到内存与硬盘中, async 则代表数据会先暂存于内存 > > 当中,而非直接写入硬盘 > > no_root_squash > > root_squash: > > 若客户端在共享目录里创建的文件的所属者和所属组是 root 用户 和 root 组, > > 那么显示文件的属主和属组时有以下两种情况: no_root_squash 表示,文件 > > 的所属者和所属组是 root 用户和 root 组; root_squash 表示将 root 用户和组 > > 映射为匿名用户和组 (默认设置)。 > > all_squash > > no_all_squash > > : > > all_squash: 客户端所有用户创建文件时,客户端会将文件的用户 和组映射为 > > 匿名用户和组 no_all_squash: 客户端普通用户创建的 文件的 UID 和 GID 是多 > > 少,服务端就显示为多少(默认设置) > > anonuid= > > anongid= > > 将文件的用户和组映射为指定的 UID 和 GID ,若不指定默认为 > > 65534 ( nfsnobody ) # 客户端( 192.168.144.132 ) \[root@client \~\] # showmount -e 192.168.144.131 Export list for 192 .168.144.131: /data 192 .168.144.132 \[root@client \~\] # mkdir -p /nfsclient/client-data/ \[root@client \~\] # mount 192.168.144.131:/data /nfsclient/client-data/ ##### **3.配置** **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 yb /etc/auto.master /client /etc/auto.yb # 本地端目录 具体挂载配置文件 \[root@client \~\] # cat /etc/auto.yb upload 192 .168.144.131:/nfs/upload # 本地端子目录 挂载参数 服务器 : 服务器对应目录 \[root@client \~\] # systemctl restart autofs # 触发自动挂载 \[root@client \~\] # cd /client \[root@client \~\] # cd upload

相关推荐
ZLRRLZ9 分钟前
【Linux操作系统】进程控制
linux·运维·服务器
我想吃余21 分钟前
Linux的Ext文件系统:硬盘理解和inode及软硬链接
linux·运维·电脑
qq762118221 小时前
Linux c 在内存中创建zip,最后写入测试
linux·运维·服务器
jayxuyj1 小时前
MySQL8.0新特性探秘深入解析窗口函数的性能优化策略
服务器
故事很腻i1 小时前
安装elk
运维·elk·jenkins
华纳云IDC服务商1 小时前
网站服务器频繁掉线的主要原因是什么
运维·服务器
小黄人软件1 小时前
【部署python网站】宝塔面板 小目标2:实时搜索网上资源文件网站放在服务器上 用AI做一个作品,不断迭代。
运维·服务器
未来之窗软件服务2 小时前
服务器运维(四)服务器漏洞扫描工具与审查——东方仙化神期
运维·服务器·仙盟创梦ide·东方仙盟·东方仙盟运维
小猪写代码2 小时前
服务器相关:什么是 alios. centos. cuda. cuda tookit. gcc. cudann. pytorch.
服务器·pytorch·centos
云飞云共享云桌面2 小时前
SolidWorks服务器多人使用方案
大数据·运维·服务器·前端·网络·电脑·制造