nfs安装与配置

一,关于nfs

  1. 网络文件系统(NFS,NetworkFileSystem)是一种将远程主机上的分区(目录)经网络挂载到本地系统的一种机制,通过对网络文件系统的支持,用户可以在本地系统上像操作本地分区一样来对远程主机的共享分区(目录)进行操作。
  2. 特征:独立于操作系统,通过网络,让不同机器及操作系统实现文件目录的分享。NFS本身是没有提供信息传输的协议和功能的,依赖于RPC协议。RPC,远程过程调用(RemoteProcedureCall)是能使客户端执行其他系统中程序的一种机制。所以,启动nfs之前,需要先启动rpc。

二,安装nfs服务

[root@admin/]#yum install nfs-utils portmap  (centos 5)
[root@admin/]#yum install nfs-utils rpcbind  (centos 6及以上)
[root@admin/]#yum install nfs

三,服务端配置
1、创建共享目录

 [root@admin/]#mkdir /home/admin/share

2、NFS文件配置

[root@admin/]#vi /etc/exports 
/home/admin/share 192.168.1.226(rw,no_root_squash,
no_all_squash,sync)
  • ip地址后面不能又空格否则会报错。保存退出。
  • 添加的内容表示:允许ip地址192.168.1.6的计算机以读写的权限来访问/work/nfs目录。
  • rw:读/写权限,只读权限的参数为ro;
  • sync:数据同步写入内存和硬盘,也可以使用async,此时数据会先暂存于内存中,而不立即写入硬盘。
  • no_root_squash:NFS服务器共享目录用户的属性,如果用户是root,那么对于这个共享目录来说就具有root的权限。

3、重启服务

[root@admin/]#service rpcbind restart 
[root@admin/]#service nfs restart
[root@admin/]#systemctl stop firewalld   关闭防火墙

三,客户端配置

1、查看是否能访问nfs服务

[root@admin/]#showmount -e 192.168.1.226

2、创建本地的数据目录

[root@admin/]#mkdir /home/admin/data

3、挂载服务端的/home/admin/share目录

[root@admin/]#mount -o nolock -t nfs 192.168.2.226:/home/admin/share   /home/admin/data
  • 此时本地目录下的data中便有了服务端share文件夹下的内容

4、查看系统挂载目录

[root@admin/]#df -h

5、解除挂载

[root@admin/]#umount /home/admin/data
  • 如果客户端想要更换服务端共享的目录,在服务端编辑完exports文件重启服务后,客户端便需要先解除挂载/home/admin/data,然后重新挂载新的共享目录。

三,进阶教程

1. /etc/exports文件内容格式:

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

输出目录是指NFS系统中需要共享给客户机使用的目录;

b.客户端:

客户端是指网络中可以访问这个NFS输出目录的计算机

客户端常用的指定方式

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

c.选项:

选项用来设置输出目录的访问权限、用户映射等。

NFS主要有3类选项:

访问权限选项

  • 设置输出目录只读:ro
  • 设置输出目录读写:rw

用户映射选项

  • all_squash:将远程访问的所有普通用户及所属组都映射为匿名用户或用户组(nfsnobody);
  • no_all_squash:与all_squash取反(默认设置);
  • root_squash:将root用户及所属组都映射为匿名用户或用户组(默认设置);
  • no_root_squash:与rootsquash取反;
  • anonuid=xxx:将远程访问的所有用户都映射为匿名用户,并指定该用户为本地用户(UID=xxx);
  • anongid=xxx:将远程访问的所有用户组都映射为匿名用户组账户,并指定该匿名用户组账户为本地用户组账户(GID=xxx);

其它选项

  • secure:限制客户端只能从小于1024的tcp/ip端口连接nfs服务器(默认设置);
  • insecure:允许客户端从大于1024的tcp/ip端口连接服务器;
  • sync:将数据同步写入内存缓冲区与磁盘中,效率低,但可以保证数据的一致性;
  • async:将数据先保存在内存缓冲区中,必要时才写入磁盘;
  • wdelay:检查是否有相关的写操作,如果有则将这些写操作一起执行,这样可以提高效率(默认设置);
  • no_wdelay:若有写操作则立即执行,应与sync配合使用;
  • subtree:若输出目录是一个子目录,则nfs服务器将检查其父目录的权限(默认设置);
  • no_subtree:即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值