在嵌入式linux的开发中, tftp & NFS这两套server是要经常使用的,下面
来谈谈NFS的安装与配置。tftp的相关内容请参考:tftp的安装与配置
系统: ubuntu9.10
软件: nfs-kernel-server, nfs-common, portmap, 相关库.
1. 安装
使用命令:
$sudo apt-get install nfs-kernel-server
命令执行后apt会自动分析依赖关系,并安装必要的软件包:
libgssglue1 libnfsidmap2 librpcsecgss3 nfs-common nfs-kernel-server portmap.
如下图所示: 2. 配置
编辑文件/etc/exports,在其末尾添加如下内容:
/rootfs *(rw,sync,no_root_squash) 说明如下:
其中:/rootfs是要共享的目录,*代表允许所有的网络段访问,rw是可读写权限,sync是资料同步写入
内存和硬盘,no_root_squash是nfs客户端分享目录使用者的权限,如果客户端使用的是root用户,那
么对于该共享目录而言,该客户端就具有root权限。
其它nfs常用的参数有:
ro 只读访问
rw 读写访问sync 所有数据在请求时写入共享
async nfs在
写入数据前可以响应请求
secure nfs通过1024以
下的安全TCP/IP端口发送
insecure nfs通过1024以上的端口发送
wdelay 如果多个用户要写入nfs目录,则归组写入(默认)
no_wdelay 如果多个用户要写入nfs目
录,则立即写入,当使用async时,无需此设置。
hide 在nfs共享目录中不共享其子目录
no_hide 共享nfs目录的子目录
subtree_check 如果共享/usr/bin之
类的子目录时,强制nfs检查父目录的权限(默认)
no_subtree_check 和
上面相对,不检查父目录权限
all_squash 共享文件的UID和GID映
射匿名用户anonymous,适合公用目录。
no_all_squash 保留共享文件的UID和GID(默认)
root_squash root用户的所有请求映射成如anonymous用户一样的权限(默认)
no_root_squas root用
户具有根目录的完全管理访问权限
anonuid=xxx 指定nfs服
务器/etc/passwd文件中匿名用户的UID
anongid=xxx 指
定nfs服
务器/etc/passwd文
件中匿名用户的GID
3. 启动 重启服务
$sudo
/etc/init.d/portmap restart
$sudo /etc/init.d/nfs-kernel-server restart
4.测试
此时可以运行以下命令来显示一下共享出来的目录:
$showmount -e
或者可以使用以下命令把它挂载在本地磁盘上,例如将/rootfs挂载到/mnt下:
$ sudo mount -t nfs localhost:/rootfs /mnt
可以运行df命令查看是否挂载成功。查看后可以使用以下命令卸载:
$ sudo umount /mnt
5.常用操作 exportfs -rv //重新读取配置文件,在不重启NFS的前提下是配置文件马上生效
exportfs -auv //停止共享,不改变配置文件
exportfs -av //显示共享的目录
文章中部分内容来源于网络,若有侵犯到您的权益,请与我联系,我会及时处理。
阅读(1138) | 评论(0) | 转发(0) |