1、概述:
NFS(Network File System)意为网络文件系统,它最大的功能就是可以通过网络,让不同的机器不同的操作系统可以共享彼此的文件。简单的讲就是可以挂载远程主机的共享目录到本地,就像操作本地磁盘一样,非常方便的操作远程文件。本文将给大家讲解怎么在CentOS7上安装和配置NFS服务器。
1.1准备
条件有限,我们用虚拟机做测试,分别做NFS服务器和客户端,配置如下:
VMware16.0
Centos虚拟机两台
NFS服务器ip:192.168.0.77。
客户端ip:192.168.0.83。
我们要实现的目标是:在NFS服务器上共享一个目录,在客户端上可以直接操作NFS服务器上的这个共享目录下的文件。
2、NFS服务器配置
2.1 安装NFS服务
首先使用yum安装nfs服务:
yum -y install rpcbind nfs-utils
2.1.1 创建共享目录
在服务器上创建共享目录,并设置权限。
mkdir /data/share/
chmod 755 -R /data/share/
2.2 配置NFS
nfs的配置文件是 /etc/exports ,vi/etc/exports后在配置文件中加入一行:
/data/share/ 192.168.0.83/22(rw,no_root_squash,no_all_squash,sync)
这行代码的意思是把共享目录/data/share/共享给192.168.0.83这个客户端
注:客户端ip后需加上端口号,否则无法操作
ip,后面括号里的内容是权限参数,其中:
rw 表示设置目录可读写。
sync 表示数据会同步写入到内存和硬盘中,相反 rsync 表示数据会先暂存于内存中,而非直接写入到硬盘中。
no_root_squash NFS客户端连接服务端时如果使用的是root的话,那么对服务端分享的目录来说,也拥有root权限。
no_all_squash 不论NFS客户端连接服务端时使用什么用户,对服务端分享的目录来说都不会拥有匿名用户权限。
如果有多个共享目录配置,则使用多行,一行一个配置。保存好配置文件后,需要执行以下命令使配置立即生效:
exportfs -r
2.3设置防火墙
如果你的系统没有开启防火墙,那么此步骤可以省略。
NFS的防火墙除了固定的port111、2049外,还有其他服务如rpc.mounted等开启的不固定的端口,因此我们需要设置NFS服务的端口配置文件。
vi/etc/sysconfig/nfs文件,将下列内容的注释去掉,如果没有则添加:
RQUOTAD_PORT=1001
LOCKD_TCPPORT=30001
LOCKD_UDPPORT=30002
MOUNTD_PORT=1002
保存好后,将端口加入到防火墙允许策略中。执行:
firewall-cmd --zOne=public --add-port=111/tcp --add-port=111/udp --add-port=2049/tcp --add-port=2049/udp --add-port=1001/tcp --add-port=1001/udp --add-port=1002/tcp --add-port=1002/udp --add-port=30001/tcp --add-port=30002/udp --permanent
firewall-cmd --reload
注:若只为测试操作,也可直接关闭防火墙
#sudo systemctl status firewalld。 //查看防火墙状态
查看后,看到active(running)就意味着防火墙打开了。
#sudo systemctl stop firewalld。 //关闭防火墙
关闭后再查看是否关闭成功,如果看到inactive(dead)就意味着防火墙关闭了。
实际生产中不建议这么做
2.4启动服务
按顺序启动rpcbind和nfs服务:(此顺序不能颠倒,否则后续会报错)
systemctl start rpcbind
systemctl start nfs(centos7)
systemctl start nfs-server(centos8)
加入开机启动:
systemctl enable rpcbind
systemctl enable nfs(centos7)
systemctl enable nfs-server(centos8)
nfs服务启动后,可以使用命令 rpcinfo -p 查看端口是否生效。
服务器的后,我们可以使用 showmount 命令来查看服务端(本机)是否可连接:
[root@localhost ~]# showmount -e localhost
Export list for localhost:
/data/share 192.168.0.83/22
出现上面结果表明NFS服务端配置正常。
3、客户端配置
3.1安装rpcbind服务
客户端只需要安装rpcbind服务即可,一般无需安装nfs或开启nfs服务。
yum -y install rpcbind
(注:若后续操作无法使用showmount命令则此步骤建议使用命令
yum -y install rpcbind nfs-utils因为有些虚拟机可能会内置showmount命令,同时若安装nfs,需确保与nfs服务器端版本一致)
3.2挂载远程nfs文件系统
查看服务端已共享的目录:
[root@localhost ~]# showmount -e 192.168.0.77
Export list for 192.168.0.77:
/data/share 192.168.0.83/22
建立挂载目录,执行挂载命令:
mkdir -p /mnt/share
mount -t nfs 192.168.0.77:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3
如果不加 -onolock,nfsvers=3 则在挂载目录下的文件属主和组都是nobody,如果指定nfsvers=3则显示root。
如果要解除挂载,可执行命令:
umount /mnt/share
3.3开机自动挂载
如果按本文上面的部分配置好,NFS即部署好了,但是如果你重启客户端系统,发现不能随机器一起挂载,需要再次手动操作挂载,这样操作比较麻烦,因此我们需要设置开机自动挂载。我们不要把挂载项写到/etc/fstab文件中,因为开机时先挂载本机磁盘再启动网络,而NFS是需要网络启动后才能挂载的,所以我们把挂载命令写入到/etc/rc.d/rc.local文件中即可。
[root@localhost ~]# vim /etc/rc.d/rc.local
#在文件最后添加一行:
mount -t nfs 192.168.11.34:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3
保存并重启机器看看。
3.4测试验证
查看挂载结果,在客户端输入 df -h
文件系统 容量 已用 可用 已用% 挂载点
devtmpfs 895M 0 895M 0% /dev
tmpfs 910M 0 910M 0% /dev/shm
tmpfs 910M 11M 900M 2% /run
tmpfs 910M 0 910M 0% /sys/fs/cgroup
/dev/sda3 23G 4.9G 18G 22% /
/dev/sda1 297M 163M 134M 55% /boot
tmpfs 182M 28K 182M 1% /run/user/1000
tmpfs 182M 0 182M 0% /run/user/0
192.168.0.77:/data/share 36G 22G 15G 61% /mnt/share
看到最后一行,就说明已经挂载成功了。接下来就可以在客户端上进入目录/mnt/share下,新建/删除文件,然后在服务端的目录/data/share查看是不是有效果了
4、错误分析:
4.1错误一:exportfs -r时出错
exportfs: 192.168.0.252:/data/share: Function not implemented
解决:
注意在vi /etc/exports时
加入的一行配置应该包括ip地址的端口号
如
/data/share/ 192.168.0.252/22(rw,no_root_squash,no_all_squash,sync)
否则会报错
4.2错误二:showmount -e localhost时报错
clnt_create: RPC: Program not registered
原因:很可能是因为nfs未正常启动
解决:
注意启动顺序
#先启动rpcbind,不然无法启动nfs
4.3错误三:在客户端测试时,发现无法使用showmount命令
缺少showmount命令
解决:CentOS安装某个缺少的命令比如showmount,ifconfig
4.4错误四:requested NFS version or transport protocol is not supported
需求的nfs版本或传输协议不支持
分析:nfs服务器上
客户端
原因:之前因为服务器上没有showmount命令,因此安装了nfs-utils.x86_64导致服务器和客户端的nfs版本不一致
解决:先卸载客户端的nfs-utils.x86_64
然后重新安装同一版本的nfs
解决方法:这边建议安装centos8的虚拟机,因为centos7,8的yum内核版本相差太大,直接用yum安装yum -y install rpcbind nfs-utils
时nfs的版本相差两个等级,且无法回退版本,导致mount挂载时无法操作
4.5错误五:mount -t挂载时,显示connection refused
解决方法:nfsvers=3,vers=3;或nfsvers=2,vers=2,
以及确定格式mount -t (nfs 服务端IP) 192.168.0.77:挂载目录是否无误