一、 Linux服务器端



以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/ 
   NFS start 


用户也可以重新启动 Linux 服务器,自动启动 NFS 服务。



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



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

# mount –t  
   NFS 192.168.0.20:/home/work /mnt  
  
 
  

    # ls /mnt


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



二、 嵌入式目标系统




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



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



选中file systems-》network file systems-》下的root file system on NFS 和 NFS file system support重新编译内核下载bootloader和kernel到开发板上



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



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

    # mount –t 
   NFS 192.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 为 嵌入式设备上的本地目录。


转载于:https://blog.51cto.com/chunk/1059551