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

(未完待续)

相关推荐
段帅龙呀2 小时前
Redis构建缓存服务器
服务器·redis·缓存
乌鸦不像写字台2 小时前
【docker部署】在服务器上使用docker
服务器·docker·容器
互联网搬砖老肖4 小时前
运维打铁: MongoDB 数据库集群搭建与管理
运维·数据库·mongodb
Antonio9155 小时前
【音视频】HLS简介与服务器搭建
运维·服务器·音视频
kfepiza5 小时前
Debian的`/etc/network/interfaces`的`allow-hotplug`和`auto`对比讲解 笔记250704
linux·服务器·网络·笔记·debian
无妄-20246 小时前
软件架构升级中的“隐形地雷”:版本选型与依赖链风险
java·服务器·网络·经验分享
艾伦_耶格宇6 小时前
【docker】-1 docker简介
运维·docker·容器
R.X. NLOS6 小时前
VS Code远程开发新方案:使用SFTP扩展解决Remote-SSH连接不稳定问题
运维·服务器·ssh·debug·vs code
cuijiecheng20186 小时前
Ubuntu下布署mediasoup-demo
linux·运维·ubuntu
轩情吖10 小时前
Qt的第一个程序(2)
服务器·数据库·qt·qt creator·qlineedit·hello world·编辑框