Ubuntu )

  Ubuntu上默认是没有安装Ubuntu nfs服务器的,因此我们首先安装Ubuntu nfs服务器端:

    $sudo apt-get install nfs-kernel-server

  (nfs-common和portmap,不用安装。因为在安装nfs-kernel-server时,apt会自动为我们把它们安装好。)

2、配置/etc/exports(NFS服务器最主用的配置文件)

  Ubuntu nfs 将允许挂载的目录及权限在文件 /etc/exports 中进行了定义。

  例如,我们要将根目录下的 home 目录共享出来,那么我们需要在 /etc/exports 文件末尾添加如下一行:

  /home/workspaces 192.168.1.0/24(rw,sync,no_root_squash)

  其中:/home 是要共享的目录,192.168.1.0/24 代表允许访问的网段,rw 是可读写权限, sync 是资料同步写入内存和硬盘,no_root_squash 是Ubuntu nfs 客户端分享目录使用者的权限,如果客户端使用的是root 用户,那么对于该共享目录而言,该客户端就具有root 权限。

例:/home/workspaces *(rw,sync,no_root_squash)

其它Ubuntu 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、Ubuntu nfs重启服务

  RPC主程序:

  $:sudo /etc/init.d/portmap restart

  NFS主程序:

  $:sudo /etc/init.d/nfs-kernel-server restart

 

  通过查看网络端口状态可以判断服务器是否成功开启:

  $:sudo netstat -tlunp

  若发现有针对111端口及2049端口的监听,则说明服务器开启成功了。

  查看RPC相关信息的命令如下:

  $:sudo rpcinfo -p localhost

  或者查看文件 /etc/rpc

 

4、在开发板上加载NFS文件

    $ sudo mount -t nfs 192.168.1.100:/home/workspaces /opt/test

  可以运行df命令查看是否挂载成功。

$ sudo umount /mnt

Added infor:

1. 问题:
rpc.nfsd:writing fd to kernel failed: errno 111
解决:
service rpcbind restart

2. 问题:
protocol not supported
分析:
内核不支持该协议
解决:
去掉-o nolock vers=2