当前位置:首页 > 嵌入式 > 嵌入式硬件
[导读]NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源。在nfs的应用中,本地nfs的客户端应用可以

NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源。在nfs的应用中,本地nfs的客户端应用可以透明地读写位于远端nfs服务器上的文件,就像访问本地文件一样。nfs作为一种将远程主机上的分区(目录)经网络挂载到本地系统的一种机制,嵌入式开发者经常需要到。

nfs有很多实际应用。下面是比较常见的一些:

1. 多个机器共享一台CDROM或者其他设备。这对于在多台机器中安装软件来说更加便宜跟方便。

2. 在大型网络中,配置一台中心 nfs服务器用来放置所有用户的home目录可能会带来便利。这些目录能被输出到网络以便用户不管在哪台工作站上登录,总能得到相同的home目录。

3. 不同客户端可在nfs上观看影视文件,节省本地空间。

4. 在客户端完成的工作数据,可以备份保存到nfs服务器上用户自己的路径下。

nfs是运行在应用层的协议。随着nfs多年的发展和改进,nfs既可以用于局域网也可以用于广域网,且与操作系统和硬件无关,可以在不同的计算机或系统上运行。

在嵌入式linux 的开发过程中,开发者需要在linux 服务器上进行所有的软件开发,交叉编译后,通用FTP 方式将可执行文件下载到嵌入式系统运行,但这种方式不但效率低下,且无法实现在线的调试。因此,可以通过建操作linux 服务器,同时可以在线对程序进行调试和修改,大大的方便了软件的开发。因此,nfs的是嵌入式linux 开发的一个重要的组成部分,本部分内容将详细说明如何配置嵌入式linux 的nfs开发环境。

嵌入式linux 的nfs开发环境的实现包括两个方面:一是linux 服务器端的nfs服务器支持;二是嵌入式目标系统的nfs客户端的支持。因此,nfs开发环境的建立需要配置linux 服务器端和嵌入式目标系统端。

一、linux 服务器端nfs服务器的配置

以root 身份登陆linux 服务器,编辑/etc 目录下的共享目录配置文件exports,指定共享目录及权限等。

执行如下命令编辑文件/etc/exports:

# vi /etc/exports

在该文件里添加如下内容:

/home/work 192.168.0.*(rw,sync,no_root_squash)

然后保存退出。

添加的内容表示:允许ip 地址范围在192.168.0.*的计算机以读写的权限来访问/home/work 目录。

/home/work 也称为服务器输出共享目录。

括号内的参数意义描述如下:

rw:读/写权限,只读权限的参数为ro;

sync:数据同步写入内存和硬盘,也可以使用async,此时数据会先暂存于内存中,而不立即写入硬盘。

no_root_squash:nfs服务器共享目录用户的属性,如果用户是 root,那么对于这个共享目录来说就具有 root 的权限。

接着执行如下命令,启动端口映射:

# /etc/rc.d/init.d/portmap start

最后执行如下命令启动nfs服务,此时nfs会激活守护进程,然后就开始监听 Client 端的请求:

# /etc/rc.d/init.d/nfsstart

用户也可以重新启动linux 服务器,自动启动nfs服务。

在nfs服务器启动后,还需要检查linux 服务器的防火墙等设置(一般需要关闭防火墙服务),确保没有屏蔽掉nfs使用的端口和允许通信的主机,主要是检查linux 服务器iptables,ipchains 等选项的设置,以及/etc/hosts.deny,/etc/hosts.allow 文件。

我们首先在linux 服务器上进行nfs服务器的回环测试,验证共享目录是否能够被访问。在linux 服务器上运行如下命令:

# mount –t nfs192.168.0.20:/home/work /mnt

# ls /mnt

命令将linux 服务器的nfs输出共享目录挂载到/mnt 目录下,因此,如果nfs正常工作,应该能够在/mnt 目录看到/home/work 共享目录中的内容。

二、嵌入式目标系统nfs客户端的配置

在linux 服务器设置好后,还需要对客户端进行相关配置。在配置内核时选择Load an Alternate Configuration File输入配置文件的路径和文件名添加内核对nfs的支持:

选中networking options-》IP:kernel level auloconfiguralion项

选中file systems-》network file systems-》下的root file system on nfs

和nfsfile system support重新编译内核下载bootloader和kernel到开发板上

在嵌入式目标系统的linux Shell 下,执行如下命令来进行nfs共享目录挂载:

# mkdir /mnt/nfs//建立linux 服务器输出共享目录的挂载点;

# mount –t nfs192.168.0.20:/home/work /mnt/nfs–o nolock

# cd /mnt/nfs

# ls

此时,嵌入式目标系统端所显示的内容即为linux 服务器的输出目录的内容,即linux 服务器的输出目录/home/work 通过nfs映射到了嵌入式目标系统的/mnt/nfs目录。用户可以用增/删/修改文件的方式来验证实际效果。mount 命令中的192.168.0.20 为linux 服务器的IP 地址,/home/work 为linux 服务器端所配置的共享输出目录,/mnt/nfs为嵌入式设备上的本地目录。

 


在开发过程中,来回输入命令非常烦人,我写了两个简单的脚本来完成nfs的启动,挂载。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

虽然嵌入式芯片架构市场上有明确的引领者,但该行业正在快速扩张,预计未来几年将出现许多新的机会。当然,在这样的热门行业中,永远有创新技术和新产品的一席之地。

关键字: 嵌入式 处理器 RISC-V

双系统将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对双系统的相关情况以及信息有所认识和了解,详细内容如下。

关键字: 双系统 Windows Linux

2024年3月8日 – 专注于引入新品的全球电子元器件和工业自动化产品授权代理商贸泽电子 (Mouser Electronics) 即日起供货Advantech的VEGA-P110 PCIe Intel® Arc A37...

关键字: 嵌入式 GPU卡 边缘AI

康佳特采用博世力士乐的 ctrlX OS 操作系统

关键字: 计算机模块 嵌入式 机器人

先楫新一代的仪表显示产品具有高画质、低功耗等特点。

关键字: 嵌入式 GPU 图形处理器

在这篇文章中,小编将为大家带来嵌入式开发的相关报道。如果你对本文即将要讲解的内容存在一定兴趣,不妨继续往下阅读哦。

关键字: 嵌入式 嵌入式开发

以下内容中,小编将对嵌入式开发的相关内容进行着重介绍和阐述,希望本文能帮您增进对嵌入式开发的了解,和小编一起来看看吧。

关键字: 嵌入式 嵌入式开发 嵌入式系统

本文中,小编将对嵌入式开发予以介绍,如果你想对它的详细情况有所认识,或者想要增进对嵌入式的了解程度,不妨请看以下内容哦。

关键字: 嵌入式 嵌入式开发

在这篇文章中,小编将为大家带来嵌入式开发的相关报道。如果你对本文即将要讲解的内容存在一定兴趣,不妨继续往下阅读哦。

关键字: 嵌入式 嵌入式开发
关闭
关闭