Linxu实验五——NFS服务器

一.NFS服务器介绍

NFS服务器 (Network File System)是一种基于网络的分布式文件系统协议,允许不同操作系统的主机通过网络共享文件和目录3。其核心作用在于实现跨平台的资源透明访问,例如在Linux和Unix系统之间共享静态数据(如视频、图片等

核心作用

  1. 跨平台文件共享:使不同操作系统的客户端能像访问本地磁盘一样操作远程文件。
  2. 简化存储管理 :集中存储数据,客户端通过挂载点访问,降低多节点数据冗余2
  3. 权限控制 :通过RPC注册的守护进程(daemons)管理客户端登录和操作权限1
  4. 扩展性支持:可结合quota等机制实现磁盘配额管理

工作原理

  1. C/S架构

    NFS采用客户端-服务器模型,服务端配置共享目录(如/home/public),客户端通过挂载命令将其映射到本地文件系统(如/mnt/nfs

  2. RPC依赖

    • NFS启动时需向RPC(Remote Procedure Call)注册服务信息,包括端口号和功能。
    • 客户端通过RPC查询可用服务,再与NFS服务端建立通信5
  3. 工作流程

    客户端请求 → RPC查询NFS服务 → 获取端口信息 → 建立NFS连接 → 读写远程文件

  4. 权限与虚拟文件系统

    • 服务端通过/etc/exports定义共享规则(如 192.168.88.0/24(rw,sync)5
    • 客户端挂载后,通过VFS(虚拟文件系统)层将远程操作转换为网络请求3

技术特点

特性 说明
RPC依赖 必须运行rpcbind服务实现动态端口分配1 5
权限控制 通过nfsdmountd守护进程分别管理访问权限和文件操作1
配置灵活性 支持IP白名单、读写模式(ro/rw)、数据同步策略(sync/async)5
版本兼容性 主流版本包括NFSv3(广泛兼容)和NFSv4(增强安全性)4

二.NFS服务器搭建

1.安装NFS服务器软件

在Ubuntu上安装NFS服务器软件,可以通过以下命令完成

复制代码
sudo apt update
sudo apt install nfs-kernel-server  //这条命令会安装NFS服务器的核心组件。

2. 创建共享目录

选择一个目录作为共享目录,或者创建一个新的目录。例如,创建一个名为sudo mkdir -p /home/www/nfs/shared的目录:

复制代码
sudo mkdir -p /home/www/nfs/shared

然后,设置该目录的权限。根据实际需求,可以将该目录的所有者设置为nobody用户组,并设置适当的读写权限:

复制代码
sudo chown nobody:nogroup /home/www/nfs/shared
sudo chmod 777 /home/www/nfs/shared

3.配置NFS共享

编辑NFS配置文件/etc/exports,以定义哪些目录需要共享以及哪些主机能够访问这些目录。使用以下命令打开/etc/exports文件:

复制代码
sudo vim /etc/exports

在文件末尾添加如下行,表示将/home/www/nfs/shared目录共享给网络中的任何主机(假设你的NFS客户端IP范围是192.168.168.128/24,你可以根据需要调整,我这里直接用主机的):

复制代码
/home/www/nfs/shared 192.168.168.128/24(rw,sync,no_subtree_check)
  • /home/www/nfs/shared:NFS共享的目录。
  • 192.168.168.128/24:允许访问的客户端IP地址范围,也可以使用具体的IP地址或域名。
  • rw:读写权限。
  • sync:同步写入数据,保证数据的安全性。确保所有写入操作在返回前完成
  • no_subtree_check:不检查父目录的权限,提高效率。

4.导出NFS共享

使配置生效,运行以下命令:

复制代码
sudo exportfs -a

5.启动NFS服务

启动并启用NFS服务,使其在启动时自动运行:

复制代码
sudo systemctl start nfs-kernel-server
sudo systemctl enable nfs-kernel-server

6.配置防火墙(可选)

如果系统使用了防火墙,需要确保允许NFS服务的相关端口。例如,可以使用ufw命令来允许特定IP地址范围的访问:

复制代码
sudo ufw allow from 192.168.168.128/24 to any port nfs

或者,如果希望允许所有网络上的主机访问NFS服务:

复制代码
sudo ufw allow from any to any port nfs

7. 检查NFS共享状态

确认NFS服务器正在运行,并检查共享目录:

复制代码
sudo exportfs -v

(未完待续)

相关推荐
chalmers_1525 分钟前
服务器启动的时候就一个对外的端口,如何同时连接多个客户端?
运维·服务器·网络
@木辛梓26 分钟前
linux 信号
linux·运维·服务器
初学者521328 分钟前
服务器映射外网端口22连接不上,局域网能通
运维·服务器·ubuntu
一周困⁸天.28 分钟前
Keepalived双机热备
linux·运维·keepalived
漏刻有时29 分钟前
宝塔面板:基于 top 命令的服务器运行状态深度分析
运维·服务器
Ponp_1 小时前
Ubuntu 22.04 + ROS 2 Humble实现YOLOV5目标检测实时流传输(Jetson NX与远程PC通信)
linux·运维·yolo
亿坊电商3 小时前
PHP后端项目中多环境配置管理:开发、测试、生产的优雅解决方案!
服务器·数据库·php
gfdgd xi5 小时前
GXDE 内核管理器 1.0.1——修复bug、支持loong64
android·linux·运维·python·ubuntu·bug
我命由我123456 小时前
Derby - Derby 服务器(Derby 概述、Derby 服务器下载与启动、Derby 连接数据库与创建数据表、Derby 数据库操作)
java·运维·服务器·数据库·后端·java-ee·后端框架
拥友LikT7 小时前
惠普DL380,Bios设置了U盘启动以后,读不到U盘(其他品牌服务器解决思路类似)
服务器·系统安装