1. NFS服务简介
NFS 是Network File System的缩写,即网络文件系统。一种使用于分散式文件系统的协定,由Sun公司开发,于1984年向外公布。功能是通过网络让不同的机器、不同的操作系统能够彼此分享个别的数据,让应用程序在客户端通过网络访问位于服务器磁盘中的数据,是在类Unix系统间实现磁盘文件共享的一种方法。
NFS 的基本原则是“容许不同的客户端及服务端通过一组RPC分享相同的文件系统”,它是独立于操作系统,容许不同硬件及操作系统的系统共同进行文件的分享。
NFS在文件传送或信息传送过程中依赖于RPC协议。RPC,远程过程调用 (Remote Procedure Call) 是能使客户端执行其他系统中程序的一种机制。NFS本身是没有提供信息传输的协议和功能的,但NFS却能让我们通过网络进行资料的分享,这是因为NFS使用了一些其它的传输协议。而这些传输协议用到这个RPC功能的。可以说NFS本身就是使用RPC的一个程序。或者说NFS也是一个RPC SERVER。所以只要用到NFS的地方都要启动RPC服务,不论是NFS SERVER或者NFS CLIENT。这样SERVER和CLIENT才能通过RPC来实现PROGRAM PORT的对应。可以这么理解RPC和NFS的关系:NFS是一个文件系统,而RPC是负责负责信息的传输。
2. NFS服务安装
# yum -y install nfs-utils //自动安装NFS服务
# yum -y install rpcbind
3. 配置NFS服务
# vim /etc/exports //添加文件目录和权限
/app/photos 10.168.8.139(rw,all_squash,sync,anonuid=500,anongid=500)
//# exportfs –r //使配置生效
说: 10.168.8.139是要挂载/app/photos目录的服务器IP
/etc/exports 配置说明:
/app/photos 10.168.8.139(rw,all_squash,sync,anonuid=500,anongid=500)
rw:read-write,可读写;
ro:read-only,只读;
sync:文件同时写入硬盘和内存;
async:文件暂存于内存,而不是直接写入内存;
no_root_squash:NFS客户端连接服务端时如果使用的是root的话,那么对服务端分享的目录来说,也拥有root权限。显然开启这项是不安全的。
root_squash:NFS客户端连接服务端时如果使用的是root的话,那么对服务端分享的目录来说,拥有匿名用户权限,通常他将使用nobody或nfsnobody身份;
all_squash:不论NFS客户端连接服务端时使用什么用户,对服务端分享的目录来说都是拥有匿名用户权限;
anonuid:匿名用户的UID值,通常是nobody或nfsnobody,可以在此处自行设定; 如: root的uid=0
anongid:匿名用户的GID值。如: root的GID=0
4. 启动NFS服务
# service rpcbind start
# service nfs start //启动NFS服务
5. 重启NFS服务
# service nfs restart //重新启动NFS服务
6.测试NFS服务
# showmount –e //查看本机是否有可挂载的目录
# showmount –e 10.168.5.62 //查看远程服务器是否有可挂载的目录
7. 挂载共享目录
# mount -t nfs -o rw 10.168.5.2:/app/photos /app/photos/
#10.168.5.2是NFS服务的IP
8. 解除挂载
# umount /app/photos