搭建环境ubuntu12.04 64位
-
执行命令:sudo apt-get install nfs-kernel-server
-
执行命令:mkdir /mount 建立一个nfs服务的专有的文件夹
-
设置NFS服务器需要的共享目录
vim/vi/gedit /etc/exports 打开文件(三种方式vim vi gedit)
/mount *(rw,no_root_squash,sync)
…可以添加多个共享目录 -
生效共享路径
exportfs -r 立即生效共享路径
exportfs -v 输出已经生效的共享路径 -
启动NFS服务器
service nfs restart 复位NFS服务器
service nfs start 启动NFS服务器
service nfs stop 停止NFS服务器 -
挂载mount
mount -t nfs 192.168.2.3:/mount /work/
192.168.2.3 服务器IP地址 (ifconfig linux环境下查看网卡信息)
mount(共享目录)
work(本地目录)
如果挂载提示设备资源上锁,使用以下命令:
mount -t nfs -o nolock 192.168.2.3:/mount /work/
其中192.168.2.3为主机ip地址 :/mount主机挂载目录
/work 开发板目录
介绍:
其中:/mount 是要共享的目录,
*代表允许所有的网络段访问,
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
7、Ubuntu nfs重启服务 (上面5,6两个步骤不行,按改步骤修改测试)
$sudo /etc/init.d/rpcbind restart
$sudo /etc/init.d/nfs-kernel-server restart
8、测试Ubuntu nfs
此时可以运行以下命令来显示一下共享出来的目录:
$showmount -e
或者可以使用以下命令把它挂载在本地磁盘上,
例如将/mount 挂载到/mnt下:
$ sudo mount -t nfs localhost:/mount /mnt
可以运行df命令查看是否挂载成功。
(这样,在/mnt目录下创建目录,/mount 下也会出现)
查看后可以使用以下命令卸载:
$ sudo umount /mnt