NFS服务器

1**、简介**

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 主配置文件(文件不一定存在) /usr/sbin/showmount 该命令主要用在 client 端。这个命令可以查看 NFS 共享出来的目录资源 # 服务端 (192.168.168.128) \[root@server data\] # mkdir /data \[root@server data\] # cat /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 ;也可以使用 \* 表示所有主机

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

相关推荐
ManageEngineITSM14 小时前
技术的秩序:IT资产与配置管理的现代重构
大数据·运维·数据库·重构·工单系统
Bony-16 小时前
Go语言完全学习指南 - 从基础到精通------语言基础篇
服务器·开发语言·golang
阿巴~阿巴~16 小时前
线程安全单例模式与懒汉线程池的实现与优化
linux·服务器·单例模式·线程池·饿汉模式·懒汉模式·静态方法
大隐隐于野16 小时前
tcp 丢包分析
linux·服务器·网络
梦昼初DawnDream17 小时前
linux安全基线
linux·运维·安全
Broken Arrows17 小时前
在Linux系统中,top命令的显示参数详解
linux·运维·服务器
APIshop17 小时前
PHP:一种强大的服务器端脚本语言
服务器·php
code-vibe19 小时前
物理机 kali 改造笔记 (一)
linux·运维·服务器
小坏讲微服务19 小时前
五分钟使用 Docker-compose搭建 Redis 8.0 中间件
运维·redis·docker·中间件·容器·kubernetes·k8s
老黄编程20 小时前
03-gpg(证书管理 )详细范例
linux·运维·ubuntu·数字证书