nfs 文件共享能解决在集群环境下图片、附件等文件共享的问题。
现在假设有两台机器192.168.1.10和192.168.1.11
我们将192.168.1.10做为服务端,192.168.1.11作为客户端。
一、服务端操作
1. 检查安装nfs服务
1
2
|
rpm -qa| grep nfs
rpm -qa| grep rpcbind
|
若没有这安装nfs-utils和rpcbind
1
|
yum install nfs-utils rpcbind
|
如上图就是安装成功了。
2.设置开机自动启动服务
1
2
|
chkconfig nfs on
chkconfig rpcbind on
|
3.启动服务
1
2
|
service rpcbind start
service nfs start
|
4.创建共享目录
mkdir /usr/local/jsp/www
5.打开/etc/exports文件
1
|
vi /etc/exports
|
加入
1
|
/usr/local/jsp/www *(rw,sync,no_root_squash)
|
* :允许所有的网段访问
rw :读写权限
sync:资料同步写入内在和硬盘
no_root_squash:nfs客户端共享目录使用者权限
如果需要指定只对某个网段(如192.168.1.1~192.168.1.192)可以这样设置
1
|
/usr/local/www/ 192.168.1.*(rw,sync,no_root_squash,no_subtree_check)
|
也可以手动指定多个网段
/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)
多目录共享添加多行即可。
6.刷新配置立即生效
1
|
exportfs -a
|
此时可用showmount -e 服务端ip来查看可mount目录
1
|
showmount -e 192.168.1.10
|
二、客户端端操作(前四步和服务端一样)
1.检查安装nfs
1
|
yum install nfs-utils rpcbind
|
2.设置开机自动启动服务
1
2
|
chkconfig nfs on
chkconfig rpcbind on
|
3.启动服务
1
2
|
service rpcbind start
service nfs start
|
4.创建共享目录
mkdir /usr/local/jsp/www
5.挂载目录
1)查看可挂载目录
1
|
showmount -e 192.168.1.10
|
2)挂载
1
|
mount -t nfs 192.168.1.10:/usr/local/jsp/www /usr/local/jsp/www
|
这一命令就已经将10上的/usr/local/jsp/www 目录挂载到客户机的/usr/local/jsp/www目录上了
挂载超时的话就检查防火墙配置,可 service iptables stop临时关闭防火墙进行测试。
3)查看已已挂载目录
1
|
df -h
|
4)卸载已挂载目录
1
|
umount /usr/local/jsp/www
|
6.设置开机自动挂载
1
2
|
vi /etc/fstab
192.168.1.10:/usr/local/jsp/www nfs rw,tcp,intr 0 1
|
三、附录nfs常用参数
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
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
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/supercrsky/article/details/79075207