zoukankan      html  css  js  c++  java
  • NFS Server搭建实践

    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是负责负责信息的传输。

    服务端

    需要的软件包

    • nfs-utils
    • rpcbind

      准备

      1
      2
      setenforce 0
      systemctl stop firewalld

    rsync工作在TCP 2049端口,你也可以添加防火墙例外
    iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 2049 -j ACCEPT

    安装

    yum install nfs-utils rpcbind -y
    配置文件以及作用

    1
    2
    3
    4
    5
    /etc/exports NFS服务的主要配置文件
    /usr/sbin/exportfs NFS服务的管理命令
    /usr/sbin/showmount 客户端的查看命令
    /var/lib/nfs/etab 记录NFS分享出来的目录的完整权限设定值
    /var/lib/nfs/xtab 记录曾经登录过的客户端信息

    /etc/exports文件格式

    1
    2
    3
    4
    <输出目录> [客户端1 选项(访问权限,用户映射,其他)] [客户端2 选项(访问权限,用户映射,其他)]
    | | |
    | | |
    /home/web 192.168.1.0/24 (rw)

    第一部分,需要分享的绝对路径
    第二部分,客户端

    • 指定ip地址的主机:192.168.0.200
    • 指定子网中的所有主机:192.168.0.0/24 192.168.0.0/255.255.255.0
    • 指定域名的主机:david.bsmart.cn
    • 指定域中的所有主机:*.bsmart.cn
    • 所有主机:*

    第三部分 只读:ro 读写:rw

    启动

    1
    2
    systemctl restart rpcbind.service
    systemctl restart nfs.service

    查看共享状态

    showmount -e  默认查看自己共享的服务
    showmount -a  显示已经与客户端连接上的目录信息

    客户端

    客户端也需要安装nfs-utils,否则挂载的时候会报错mount: wrong fs type, bad option, bad superblock on

    安装

    yum install nfs-utils rpcbind -y

    挂载

    测试挂载
    mount 192.168.1.108:/home/web/ /tmp/test/

    • 开机自动挂载
      echo "192.168.1.108:/home/web/ /tmp/test/" >> /etc/fstab
    • autofs自动挂载

    yum install autofs -y
    autofs配置包括两个文件
    /etc/auto.master 文件定义本地挂载点.
    /tmp/a /etc/auto.nfs --timeout=60
    /etc/auto.misc 配置文件是用来设置需要挂载的文件系统类型和选项
    nfs -fstype=nfs 192.168.1.63:/tmp/a/root_squash
    重启服务即可
    只有cd /tmp/a/nfs 进去, 触发一下,才能自动挂载。 另外 nfs目录,不能提前创建,自动挂载时,系统自动创建nfs目录
    参考
    http://www.cnblogs.com/mchina/archive/2013/01/03/2840040.html

    https://vsxen.github.io/2017/09/16/nfs-server/

  • 相关阅读:
    WebClient, HttpClient, HttpWebRequest ,RestSharp之间的区别与抉择(几种Http请求方法)
    关于c#里面的httpclient的调用
    mvc项目架构分享系列之架构搭建初步 架构搭建初步
    关于在.NET中 DAL+IDAL+Model+BLL+Web
    三层架构(DAL/BLL/UI)和MVC设计模式的关系
    c#开发初学者之mvc及架构分层
    c#串口编程(转)
    【WPF】对话框/消息弹窗
    WPF如何不显示最大化,最小化的按钮
    信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言——1103:陶陶摘苹果
  • 原文地址:https://www.cnblogs.com/findumars/p/8041112.html
Copyright © 2011-2022 走看看