ubuntu11.10 nfs服务器配置



      1、安装Ubuntu nfs服务器端:

[root@10.10.90.97 ~]# apt-get install nfs-kernel-server

2、配置/etc/exports


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


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


/data *(rw,sync,no_root_squash)

其中:/data 是要共享的目录

     *         代表允许所有的网络段访问

     rw       是可读写权限

     sync   是资料同步写入内存和硬盘

     no_root_squash   是Ubuntu nfs客户端分享目录使用者的权限,如果客户端使用的是root用户,那么对于该共享目录而言,该客户端就具有root权限。

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

[root@10.10.90.97 ~]# /etc/init.d/portmap restart
 [root@10.10.90.97 ~]# /etc/init.d/nfs-kernel-server restart

4、测试Ubuntu nfs

此时可以运行以下命令来显示一下共享出来的目录:

[root@10.10.90.20 ~]# showmount -e

或者可以使用以下命令把它挂载在客户端机器磁盘上,例如将/data挂载到/mnt下:

[root@10.10.90.20 ~]# mount -t nfs 10.10.90.97:/data /mnt

可以运行df命令查看是否挂载成功。查看后可以使用以下命令卸载:

[root@10.10.90.20 ~]# umount /mnt

可以将挂载命令写入/etc/fatab中,然后mount

10.10.90.97:/data  /mnt     nfs     _netdev,vers=3,noatime,nodiratime 0 0
 [root@10.10.90.20 ~]# monut -a

运行 $ sudo /etc/init.d/nfs-kernel-server restart 重启nfs服务

测试NFS:
可以尝试一下挂载本地磁盘(假设本地主机IP地址为:59.64.195.97,将/home/warmbupt/arm/nfs 挂载到/mnt)

$ sudo mount 59.64.195.97:/home/warmbupt/arm/nfs /mnt


运行 $ df 看看结果

$ sudo umount /mnt


如果 出现 permission deny:
试一试 :sudo mount -o nolock -t nfs 59.64.195.97:/home/warmbupt/arm/nfs /mnt搞定。