1.NFS概念
NFS是Network File System(网络文件系统)。
NFS客户端一般是应用(比如web,负载均衡等),可以通过挂载的方式将NFS服务器端共享的目录挂载到NFS客户端本地的目录下 。
- 主要功能:通过网络让不同的服务器之间可以共享文件或者目录。
- 优点:1.节省本地存储空间,将常用的数据存放在一台NFS服务器上且可以通过网络访问,那么本地终端将可以减少自身存储空间的使用;2.用户不需要在网络中的每个机器上都建有Home目录,Home目录可以放在NFS服务器上且可以在网络上被访问使用。3.一些存储设备如软驱、CDROM和Zip(一种高储存密度的磁盘驱动器与磁盘)等都可以在网络上被别的机器使用。这可以减少整个网络上可移动介质设备的数量。
2.NFS工作原理
- 启动RPC服务
- 启动NFS服务
- 客户端请求NFS服务
- RPC把端口和IP地址给客户端
3.NFS协议
NFS在文件传送过程中依赖与RPC(远程过程调用)协议。
NFS本身是没有提供信息传送的协议和功能的,但是能够用过网络进行图片,视频,附件等分享功能。
只要用到NFS的地方都需要启动RPC服务,不论是NFS的服务端还是客户端
4.NFS默认端口:TCP 2049
二、实际操作
NFS服务端:192.168.1.2
NFS客户端:192.168.1.3
1.安装NFS服务器
[root@c74 ~]# yum install rpcbind nfs-utils -y
2.关闭防火墙和se
[root@c74 ~]# systenctl stop firewalld
[root@c74 ~]# setenforce 0
3.配置NFS服务端
- 创建NFS共享目录
[root@c74 ~]# mkdir /data1
[root@c74 ~]# chmod -Rf 777 /data1
- NFS服务的主配置文件
[root@c74 ~]# vi /etc/exports
/data1 192.168.1.2(rw,sync,root_squash) #IP可以是网段也可以是客户端的IP地址。
#exports配置常用参数
#ro 只读
#rw 读写
#root_squash 当NFS客户端以root管理员访问时,映射为NFS服务器的匿名用户
#no_root_squash 当NFS客户端以root管理员访问时,映射为NFS服务器的root管理员
#all_squash 无论NFS客户端使用什么账户访问,均映射为NFS服务器的匿名用户
#sync 同时将数据写入到内存与硬盘中,保证不丢失数据
#async 优先将数据保存到内存,然后再写入硬盘;这样效率更高,但可能会丢失数据
4.启动NFS服务
[root@c74 ~]# systemctl restart rpcbind && systemctl enable rpcbind
[root@c74 ~]# systemctl start nfs-server && systemctl enable nfs-server
5.客户端连接服务端
showmount,主要使用命令来查询共享信息。此处测试好在其它机器测试
[root@c66 ~]# showmount -e 192.168.1.3
[root@c66 ~]# mount -t nfs 192.168.1.3:/data1 /mnt
#如果想要开机挂载,请编辑 /etc/fstab文件
6.测试
- 服务端测试
在服务端的共享文件里新建目录、文件,在客户端查看是否同步1)在服务端共享目录里新建目录11和文件22.txt2)在客户端查看 - 客户端测试
在客户端的服务端的挂载目录里新建目录、文件,在服务端查看是否同步1)在客户端挂载目录里新建目录和文件2)在服务端查看注意:在服务端创建目录和文件与在客户端创建目录和文件它们的属主、属组不同