基于 NFS 的文件共享实现

NFS(Network File System)即网络文件系统,它允许网络中的计算机之间通过 TCP/IP 网络共享文件资源,服务端通过 NFS 共享文件目录,客户端将该文件目录挂载在本地文件系统中,就可以像操作本地文件一样读写服务端文件。

在嵌入式 Linux 开发过程中,我们经常需要将在 Linux 主机交叉编译的程序文件下载到嵌入式 Linux 开发板中运行,通过使用 NFS 可大大简化操作流程。

搭建 NFS 服务

  • 执行命令安装 NFS 服务:
vbscript 复制代码
sudo apt-get install nfs-kernel-server
  • 输入 y,或直接回车确认,等待安装完成:
  • 在用户目录下新建 nfs-work 文件夹作为 NFS 的工作目录:
  • 使用 vi 编辑器打开 NFS 配置文件:
bash 复制代码
sudo vi /etc/exports
  • 添加 /home/alpha/nfs-work 作为 NFS 的一个工作目录
  • NFS 配置的一些常用参数总结如下:
常用参数 含义
ro 以只读的方式共享
rw 以读写的方式共享
sync 数据同步
async 数据异步
secure 客户端必须使用 NFS 保留端口( 1024 以下的端口)
insecure 允许客户端使用 1024 以上的端口访问
subtree_check 检查父目录的权限
no_subtree_check 不检查父目录权限
root_squash 客户端以 root 用户访问时,赋予其匿名用户权限
no_root_squash 客户端以 root 用户访问时,赋予其 root 权限
  • 执行命令重启 rpcbind 和 NFS 服务:
bash 复制代码
sudo /etc/init.d/rpcbind restart
sudo /etc/init.d/nfs-kernel-server restart
  • 重启成功:

测试 NFS

  • 首先保证 Linux 服务主机和客户机相互 ping 通,主机 ping 客户机 IP:
  • 客户机 ping 主机 IP:
  • 客户机执行 mount 命令将主机 NFS 工作目录挂载在本地 /mnt/ 目录下:
ruby 复制代码
mount -t nfs4 -o vers=4 192.168.0.120:/home/alpha/nfs-work /mnt/
  • 查看客户机本地目录,已创建 mnt 文件夹,且该文件夹为空:
  • 在主机 NFS 工作目录下创建 test.txt 文件并写入一些内容:
  • 在客户机查看本地 mnt 目录,test.txt 文件已经同步过来了:
  • 在客户机向 test.txt 文件中添加内容:
  • 在主机 NFS 工作目录下再次查看 test.txt 文件,内容也同步了:

更多内容

相关推荐
0xDevNull4 小时前
Linux切换JDK版本详细教程
linux
进击的丸子4 小时前
虹软人脸服务器版SDK(Linux/ARM Pro)多线程调用及性能优化
linux·数据库·后端
序安InToo1 天前
第6课|注释与代码风格
后端·操作系统·嵌入式
Johny_Zhao2 天前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
chlk1233 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑3 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件3 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
深紫色的三北六号4 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash4 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI4 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github