1. NFS简介

NFS(Network File System)网络文件系统是一个文件系统,而RPC(Remote Procedure Call)远程过程调用是负责信息的传输。

NFS在文件传送或信息传送过程中依赖于RPC协议。

2. 服务端配置

2.1 关闭selinux

setenforce 0    #临时关闭selinux防火墙

2.2 安装依赖包

yum install -y rpc-bind nfs-utils    

2.3 服务端配置

NFS服务的主要配置文件为:/etc/exports

输入以下内容:


/opt/tmp/ 192.168.1.0/24(rw,no_root_squash,no_all_squash,sync,anonuid=0,anongid=0)
#*为任意ip都可访问

修改对应文件夹权限:chmod 777 /opt/tmp

2.4 启动nfs

exportfs -r                 #重载配置
service rpcbind start       #启动rpc
service nfs start           #启动nfs
showmount -e 192.168.1.10   #查看挂载点(ip按实际情况修改)
          • -

exports文件内容格式 :

格式:<输出目录> 客户端(选项:[访问权限,用户映射,其他])

  1. 客户端常用的指定方式
  • 指定ip地址的主机:192.168.100.1
  • 指定一个子网:192.168.100.0/24
    也可以写成:192.168.100.0/255.255.255.0
  • 指定域名的主机:id.test.cn
    指定域中的所有主机:*.test.cn
    所有主机:*
  1. 访问权限
  • 只读:ro
  • 读写:rw
  1. 用户映射选项:
  • all_squash:将远程访问的所有普通用户及所属组都映射为匿名用户或用户组(nfsnobody)
  • no_all_squash:与all\_squash取反(默认设置)
  • root_squash:将root用户及所属组都映射为匿名用户或用户组(默认设置);
  • no_root_squash:与rootsquash取反;
  • anonuid=xxx:将远程访问的所有用户都映射为匿名用户,并指定该用户为本地用户(UID=xxx);
  • anongid=xxx:将远程访问的所有用户组都映射为匿名用户组账户,并指定该匿名用户组账户为本地用户组账户(GID=xxx);
  1. 其它选项:
  • secure:限制客户端只能从小于1024的tcp/ip端口连接nfs服务器(默认设置);
  • insecure:允许客户端从大于1024的tcp/ip端口连接服务器;
  • sync:将数据同步写入内存缓冲区与磁盘中,效率低,但可以保证数据的一致性;
  • async:将数据先保存在内存缓冲区中,必要时才写入磁盘;
  • wdelay:检查是否有相关的写操作,如果有则将这些写操作一起执行,这样可以提高效率(默认设置);
  • no_wdelay:若有写操作则立即执行,应与sync配合使用;
  • subtree:若输出录是一个子目录,则nfs服务器将检查其父目录的权限(默认设置);
  • no_subtree:即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率;
          • -

3. 客户端挂载

3.1 Linux

#挂载
mount -t nfs 192.168.1.10:/opt/test /mnt/nfs`  

#卸载
umount 192.168.1.10:/opt/tmp

3.2 Windows

需先安装NFS服务,在控制面板-程序和功能-NFS服务

打开命令提示符输入:

#挂载 格式[mount 地址:路径 挂载盘符]
mount 192.168.1.10:/opt/tmp z:

#卸载
umount z:

注:也可使用第三方nfs客户端。

标签: Centos7, 192.168, nfs, NFS, 配置, 默认设置, squash, no

相关文章推荐

添加新评论,含*的栏目为必填