APP下载

Linux下NFS(网络文件系统)的建立与配置方法

2013-04-16瑛宣

计算机与网络 2013年21期
关键词:服务器端命令分区

网络文件系统(NFS,Network File System)是一种将远程主机上的分区(目录)经网络挂载到本地系统的一种机制,通过对网络文件系统的支持,用户可以在本地系统上像操作本地分区一样来对远程主机的共享分区(目录)进行操作。

在嵌入式Linux的开发过程中,开发者需要在Linux服务器上进行所有的软件开发,交叉编译后,通用FTP方式将可执行文件下载到嵌入式系统运行,但这种方式不但效率低下,且无法实现在线的调试。因此,可以通过建立 NFS,把 Linux服务器上的特定分区共享到待调试的嵌入式目标系统上,就可以直接在嵌入式目标系统上操作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/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共享目录中的内容。

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

在Linux服务器设置好后,还需要对客户端进行相关配置。在配置内核时选择Load an Alternate Configu ration 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为嵌入式设备上的本地目录。

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

host启动 NFS:

sNFS

#!/bin/bash

ifconfig eth0 192.168.0.20

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

嵌入式目标机挂载NFS:

mNFS:

#!/bin/sh

mount -t NFS 192.168.0.20:/home/work/NFS /mnt/NFS -o nolock

echo“NFS ok!”

猜你喜欢

服务器端命令分区
只听主人的命令
上海实施“分区封控”
Linux环境下基于Socket的数据传输软件设计
浪莎 分区而治
移防命令下达后
浅析异步通信层的架构在ASP.NET 程序中的应用
基于Qt的安全即时通讯软件服务器端设计
这是人民的命令
基于SAGA聚类分析的无功电压控制分区
基于多种群遗传改进FCM的无功/电压控制分区