Ubuntu Server 12.04 NFS 文件共享设置


NFS 文件共享能解决在集群环境下图片、附件等文件共享的问题。
现在假设有两台机器192.168.1.10和192.168.1.11
我们将192.168.1.10做为服务端,192.168.1.11作为客户端。
一、服务端操作
1.安装NFS服务端
[plain]  
sudo apt-get install nfs-kernel-server  
 
2.打开/etc/exports文件,在末尾加入:
[plain] 
/home/zdw *(rw,sync,no_root_squash)  
 
其中/home/zdw 是你要共享的目录
* :允许所有的网段访问
rw :读写权限
sync:资料同步写入内在和硬盘
no_root_squash:nfs客户端共享目录使用者权限
如果需要指定只对某个网段(如192.168.1.1~192.168.1.192)可以这样设置
[plain]  
sudo /usr/local/www/ 192.168.1.*(rw,sync,no_root_squash,no_subtree_check)    
 
也可以手动指定多个网段
[plain]  
/usr/local/www/ 192.168.1.10(rw,sync,no_root_squash,no_subtree_check) 192.168.1.11(rw,sync,no_root_squash,no_subtree_check)  
 
多目录共享添加多行即可。
 
3.重启服务
[plain]  
sudo /etc/init.d/portmap restart                  <---重启portmap,  
sudo /etc/init.d/nfs-kernel-server restart      <---重启nfs服务  
showmount -e                                          <---显示共享出的目录  
 
二、客户端端操作
1.安装nfs服务
安装nfs-common或nfs-kernel-server都行
[plain]  
sudo apt-get isntall nfs-common  
[plain] 
sudo apt-get install nfs-kernel-server  
 
2.挂载
[plain] 
sudo mount -t nfs 192.168.1.10:/usr/local/www /usr/local/www  
这一命令就已经将10上的/usr/local/www 目录挂载到客户机的/usr/loca/www目录上了。
可以在客户机上挂载目录里创建一个文件进行测试。
[plain] 
sudo touch 1.txt  
加到服务端上查看发现文件已经存在了,共享成功。
3.取消挂载
[plain] 
sudo umount /usr/local/www  
 
如果取消挂载的时候提示 “/usr/local/www device is busy ” 的提示,表示目录正在使用,无法取消挂载。
这里我们可以执行如下命令:
[plain]  
fuser -km /usr/local/www  
df -lh  
 
完成后再执行umount命令就可以了。
4.开机自动挂载
如果想实现开机自动挂载,可以在/etc/rc.local文件中exit 0之前
加入我们要挂载的命令
sudo mount -t nfs 192.168.1.10:/usr/local/www /usr/local/www
即可。
 
三、附录NFS常用参数
[plain]  
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  
 

相关内容

    暂无相关文章