zoukankan      html  css  js  c++  java
  • NFS共享存储服务

    NFS(Network File System)是一种基于TCP/IP传输的网络文件系统协议,最初由SUN公司开发,通过使用NFS协议,客户机可以像访问本地目录一样访问远程服务器中的共享资源,对于大多数负载均衡集群来说,使用NFS协议来共享数据存储是一种比较常见而且节省资源,节省设备硬件投入的成本。NFS也是NAS存储设备必然支持的一种协议。

    需要一台NFS服务器,两台Web服务器

    一、使用NFS发布共享资源(NFS服务器)

    NFS服务的实现依赖于RPC机制(Remote Process Call  远程过程调用机制),以完成远程到本地的映射过程,在Centos 7中需要安装nfs-utils、rpcbind软件包来提供NFS共享服务,前者用于NFS共享发布和访问,后者用于RPC支持。

    1、安装nfs-utils、rpcbind软件包

    提供RPC支持的服务为rpcbind,提供nfs共享的服务为nfs,完成安装以后建议调整这两个服务器的自启动状态,以便每次开机时自动启动,手动加载NFS共享服务时,应该先启动rpcbind,然后再访问nfs。

    [root@localhost ~]# yum -y install nfs-utils rpcbind
    [root@localhost ~]# systemctl start rpcbind
    [root@localhost ~]# systemctl start nfs

    2、设置共享目录

    NFS的配置文件为/etc/exports,文件内容默认为空(无任何共享),在服务器192.168.200.114中的exports文件设置共享资源时,记录格式为 “目录位置   客户机地址 (权限选项)”。 例如:若要将文件夹/opt/wwwroot共享给192.168.200.0/24网段使用,允许读写操作,配置如下所示。

    [root@localhost ~]# mkdir -p /opt/wwwroot
    [root@localhost ~]# vim /etc/exports
    /opt/wwwroot 192.168.200.0/24(rw,sync,no_root_squash)

    ===========================================================
    sync:同步写入
    no_root_squash:客户机以root身份访问时会拥有NFS服务器以root身份对共享目录的权限

    其中客户机地址可以是主机名、IP地址、网段地址,允许使用*(任意字符、任意字符串)、?(任意单个字符)通配符,权限中rw表示读写(ro表示只读)

    补充:

    当需要将同一个目录共享给不同客户机,且分配不同的权限时,只要以空格分隔指定多个 “客户机   (权限设置)” 即可。例如:将/var/ftp/public目录共享给两个客户机,并分别给予只读、读写权限。

    [root@localhost ~]# vim /etc/exports
    /var/ftp/pub 192.168.200.112(ro) 192.168.200.113(rw)

    3、重启服务

    [root@localhost ~]# systemctl restart rpcbind
    [root@localhost ~]# systemctl restart nfs

    4、查看本机发布的NFS共享目录

    [root@localhost ~]# showmount -e
    Export list for localhost.localdomain:
    /opt/wwwroot 192.168.200.0/24

    在Web机上查看共享目录

    [root@localhost ~]# showmount -e 192.168.200.114   //后面加NFS服务器的IP地址
    Export list for 192.168.200.114:
    /opt/wwwroot 192.168.200.0/24

    二、在Web服务器中访问NFS共享资源(Web服务器)

    NFS的目标是提供一种网络文件系统,因此对NFS共享的访问也使用mount命令来进行挂载,对应的文件系统类型为nfs,可以手动挂载也可以加入/etc/fstab配置文件中实现开机自动挂载,考虑到群集系统中的网络稳定性,NFS服务器与客户机之间最好使用专有网络进行连接。

    1、安装软件包rpcbind、nfs-utils,并启动服务

    通过nfs-utils软件包,客户机也可以使用showmount查看共享目录,格式为 “showmont  -e  NFS服务器地址”

    [root@localhost ~]# yum -y install nfs-utils rpcbind
    [root@localhost ~]# systemctl start rpcbind
    [root@localhost ~]# systemctl start nfs

    2、手动挂载NFS共享目录

    以root用户身份执行mount操作,将NFS服务器共享的/opt/wwwroot目录挂载到本地目录/var/www/html。与挂载本地文件不同的是,设备位置处应指出服务器地址,完成挂载后,只要访问客户机的/var/www/html文件夹,实际就相当于访问NFS服务器中的/opt/wwwroot文件夹。

    [root@localhost ~]# mount 192.168.200.114:/opt/wwwroot /var/www/html/
    查看
    [root@localhost ~]# mount | tail -1
    192.168.200.114:/opt/wwwroot on /var/www/html type nfs4 (rw,relatime,vers=4.0,rsize=131072,wsize=131072,namlen=255,hard,proto=tcp,port=0,timeo=600,retrans=2,sec=sys,clientaddr=192.168.200.112,local_lock=none,addr=192.168.200.114)
    [root@localhost ~]# tail -1 /etc/mtab 
    192.168.200.114:/opt/wwwroot /var/www/html nfs4 rw,relatime,vers=4.0,rsize=131072,wsize=131072,namlen=255,hard,proto=tcp,port=0,timeo=600,retrans=2,sec=sys,clientaddr=192.168.200.112,local_lock=none,addr=192.168.200.114 0 0

    测试

    [root@localhost ~]# echo "1111111" > /opt/wwwroot/index.html (NFS服务器中)
    [root@localhost ~]# cat /var/www/html/index.html  (用客户机查看可以看见共享的内容)
    1111111

    3、fstab自动挂载

    [root@localhost ~]# vim /etc/fstab 
    192.168.200.114:/opt/wwwroot /var/www/html nfs defaults,_netdev 0 0

    ===================================================================
    /var/www/html:挂载点
    nfs:文件系统类型
    第一个 0 :是否要进行备份(0不备份,1备份)
    第二个 0 :开机是否检查文件系统完整性,检查文件系统的超级快
  • 相关阅读:
    Spark基本架构及原理
    深度剖析Spark分布式执行原理
    Spark的集群管理器
    基于Redis的开源分布式服务Codis
    RabbitMQ 概念
    分布式事务实现
    优酷 视频上传服务
    深入解析Java中volatile关键字的作用
    mysql in查询 结果乱序 引发的思考
    不安装oracle客户端,用plsql连接oracle
  • 原文地址:https://www.cnblogs.com/tanxiaojuncom/p/11630935.html
Copyright © 2011-2022 走看看