NFS共享存储服务

NFS是一种基于TCP/IP传输的网络文件系统协议,最初由SUN公司开发。通过使用NFS协议客户机可以向访问本地目录一样访问远程服务器中的共享资源。对大多数复制均衡群集来说,使用NFS协议来共享数据存储比较适用。
NFS服务的实现依赖于RPC(remote process call,远端过程调用)机制,以完成远程到本地的映射过程,在centos6中,需要安装nfs-utils,rpcbind软件包来提供NFS共享服务,前者用于NFS共享发布和访问,后者用于RPC支持。

1.安装部署:
安装nfs-utils,rpcbind,提供NFS共享的服务为nfs,完成安装以后建议调整两个服务的自启动状态,以便每次开机后自动启动。手动加载NFS共享服务时,应该先启动rpcbind,然后在启动nfs。

# yum  -y install nfs-utils rpcbind
# chkconfig nfs on
# chkconfig rpcbind on

2.设置共享目录
NFS的配置文件为/etc/exports,文件内容默认为空(无任何共享),在exports文件中设置共享资源时,记录格式为:”目录位置 客户机地址(权限选项)”。例如要将文件夹
/backup共享给192.168.152.0网段使用,允许读写操作。

# mkdir /backup
# vi /etc/exports

/backup 192.168.152.0/24(rw,sync,no_root_squash)

解释一下:
其中客户机地址可以是主机名、ip地址、允许使用“*”等通配符,多个时空格隔开即可;权限选项中的rw表示允许读写;ro为只读;sync表示同步写入,no_root_squash表示当客户机以root身份访问时赋予本地root权限(默认是root_squash,将作为nfsnobody用户降权对待)。

3.启动NFS服务:

# service rpcbind start
# service nfs start
# netstat -anpt | grep rpcbind

查看本机NFS共享目录:

# showmount -e

4.在客户机中访问NFS共享资源:
NFS协议的目标是提供一种网络文件系统,因此对NFS共享的访问也使用mount命令来进行挂载,对应得文件系统类型为nfs。
若要正常访问NFS共享资源,客户机中也需要安装rpcbind软件包,并启动rpcbind服务,另外为了使用showmount查询工具,最好将nfs-utils软件包也装上。

安装部署客户机端:

# yum  -y install rpcbind nfs-utils
# chkconfig rpcbind on
# service rpcbind start

5.查看NFS服务器端共享目录:

# showmount -e 192.168.152.130

6.手动挂载NFS共享目录:
以root用户身份执行mount操作,将NFS服务器共享的/backup目录挂载到本地目录的/usr/local/nginx/html。与挂载不同的是,设备位置应该指出服务器地址。

# mount 192.168.152.130:/backup  /usr/local/nginx/html

7.查看挂载结果:

# tail  -1 /etc/mtab(前面的-1,是数字1)

完成挂载以后,访问客户机的/usr/local/nginx/html文件夹,实际上就相当于访问NFS服务器中的/backup文件夹。其中的网络映射过程对于用户来说是透明的。