方案一: 一、NFS安装 二、NFS配置 2.1 配置/etc/exports文件 $ sudo vim /etc/exports 在文件最后加入如下内容: {{ /rootnfs *(rw,sync,no_root_squash,no_subtree_check) //必要时chmod -R 777 /rootnfs ;/opt/share 10.112.18.0/255.255.255.0(rw,no_root_squash) }} 注:nfs允许挂载的目录及权限在文件/etc/exports中进行了定义。其中:/rootnfs是要共享的目录,*代表允许所有的网络段访问,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 三、重启服务 $ sudo /etc/init.d/portmap restart $ sudo /etc/init.d/nfs-kernel-server restart 四、测试 4.1 显示出共享出来的目录 $ showmount -e 4.2 将nfs的rootnfs目录挂载到本地磁盘上。 $ sudo mount -t nfs localhost:/rootnfs /mnt 4.3 查看挂载情况 $ df 4.4 卸载挂载 $ sudo umount /mnt 五、完成 方案二: 首先安装nfs-kernel-server apt-get install nfs-kernel-server 然后创建一个目录: mkdir -p /opt/share 并赋予权限777: chmod -R 777 /opt/share 在/etc/exports文件中添加配置: /opt/share 10.112.18.0/255.255.255.0(rw,no_root_squash) 在/etc/hosts.allow中添加配置: portmap:10.112.18.0/255.255.255.0 在/etc/hosts.deny中添加配置: portmap:ALL 重新启动两个服务: service portmap restart service nfs-kernel-server restart 在另一台Ubuntu上安装nfs-common apt-get install nfs-common 然后创建目录test mkdir ~/test 然后运行测试命令看一下: # showmount -e 10.112.18.158 Export list for 10.112.18.158: /opt/share 10.112.18.0/255.255.255.0 找到nfs server的挂载目录了。现在手工挂载: mount -t nfs4 10.112.18.158:/opt/share ~/test/ 现在可以测试了,应该成功。 |
|