时间:2011-07-08
环境:Ubuntu10.10 server
1、安装nfs
Ubuntu上默认是没有安装nfs服务器的,因此我们首先安装nfs服务器端:
$sudo apt-get install nfs-kernel-server
2、配置/etc/exports
nfs允许挂载的目录及权限在文件/etc/exports中进行了定义。
例如,我们要将根目录下的rootfs目录共享出来,那么我们需要在/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、测试nfs
此时可以运行以下命令来显示一下共享出来的目录:
$showmount -e
或者可以使用以下命令把它挂载在本地磁盘上,例如将/rootfs挂载到/mnt下:
$ sudo mount -t nfs localhost:/rootfs /mnt
可以运行df命令查看是否挂载成功。查看后可以使用以下命令卸载:
$ sudo umount /mnt
环境:SUSE
1、进入到提供NFS服务的Linux主机
编辑文件/etc/exports
添加一项NFS共享目录列表
${share-dir} 10.166.144.*(rw,no_root_squash,async) *(ro)
此处,${share-dir}表示共享目录路径,10.166.144.*表示允许的外部连接地址,rw,no_root_squash,async表示连接选项及访问权限。
编辑完成,使用root用户启动NFS服务
# /sbin/service nfsserver restart
Shutting down kernel based NFS server done
Starting kernel based NFS server done
查看NFS服务是否启动:
# /sbin/service nfsserver status
Checking for kernel based NFS server: running
使用命令chkconfig nfsserver 35可将NFS服务设置为开机自启动
2、进入到访问NFS服务的Linux主机:
执行:
# mount -t nfs ${nfs-server-ip}:${share-dir} ${local-mount-dir}
挂载NFS共享目录到本地主机,其中变量nfs-server-ip为提供NFS服务的主机IP,
share-dir为共享目录路径,local-mount-dir为挂载点