CentOS7中搭建NFS⽂件共享存储服务的完整步骤
前⾔
NFS(Network File System)意为⽹络⽂件系统,它最⼤的功能就是可以通过⽹络,让不同的机器不同的操作系统可以共享彼此的⽂件。简单的讲就是可以挂载远程主机的共享⽬录到本地,就像操作本地磁盘⼀样,⾮常⽅便的操作远程⽂件。
本⽂将给⼤家讲解如何在CentOS7上安装和配置NFS服务器。
下⾯话不多说了,来⼀起看看详细的介绍吧
准备
我们需要两台CentOS7机器,我们⽤虚拟机做测试,分别做NFS服务器和客户端,配置如下:
NFS服务器ip:192.168.11.31。
客户端ip:192.168.11.34。
我们要实现的⽬标是:在NFS服务器上共享⼀个⽬录,在客户端上可以直接操作NFS服务器上的这个共享
⽬录下的⽂件。
NFS服务器配置
1.安装NFS服务
⾸先使⽤yum安装nfs服务:
yum -y install rpcbind nfs-utils
2.创建共享⽬录
在服务器上创建共享⽬录,并设置权限。
mkdir /data/share/
centos vim命令chmod 755 -R /data/share/
3.配置NFS
nfs的配置⽂件是 /etc/exports ,在配置⽂件中加⼊⼀⾏:
/
data/share/ 192.168.11.34(rw,no_root_squash,no_all_squash,sync)
这⾏代码的意思是把共享⽬录/data/share/共享给192.168.11.34这个客户端ip,后⾯括号⾥的内容是权限参数,其中:
rw 表⽰设置⽬录可读写。
sync 表⽰数据会同步写⼊到内存和硬盘中,相反 rsync 表⽰数据会先暂存于内存中,⽽⾮直接写⼊到硬盘中。
no_root_squash NFS客户端连接服务端时如果使⽤的是root的话,那么对服务端分享的⽬录来说,也拥有root权限。
no_all_squash 不论NFS客户端连接服务端时使⽤什么⽤户,对服务端分享的⽬录来说都不会拥有匿名⽤户权限。
如果有多个共享⽬录配置,则使⽤多⾏,⼀⾏⼀个配置。保存好配置⽂件后,需要执⾏以下命令使配置⽴即⽣效:
exportfs -r
4.设置防⽕墙
如果你的系统没有开启防⽕墙,那么该步骤可以省略。
NFS的防⽕墙特别难搞,因为除了固定的port111、2049外,还有其他服务如unted等开启的不固定的端⼝,这样对防⽕墙来说就⽐较⿇烦了。为了解决这个问题,我们可以设置NFS服务的端⼝配置⽂件。
修改/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
5.启动服务
按顺序启动rpcbind和nfs服务:
systemctl start rpcbind
systemctl start nfs
加⼊开机启动:
systemctl enable rpcbind
systemctl enable nfs
nfs服务启动后,可以使⽤命令 rpcinfo -p 查看端⼝是否⽣效。
服务器的后,我们可以使⽤ showmount 命令来查看服务端(本机)是否可连接:
[root@localhost ~]# showmount -e localhost
Export list for localhost:
/data/share 192.168.11.34
出现上⾯结果表明NFS服务端配置正常。
客户端配置
1.安装rpcbind服务
客户端只需要安装rpcbind服务即可,⽆需安装nfs或开启nfs服务。
yum -y install rpcbind
2.挂载远程nfs⽂件系统
查看服务端已共享的⽬录:
[root@localhost ~]# showmount -e 192.168.11.31
Export list for 192.168.11.31:
/
data/share 192.168.11.34
建⽴挂载⽬录,执⾏挂载命令:
mkdir -p /mnt/share
mount -t nfs 192.168.11.34:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3
如果不加 -onolock,nfsvers=3 则在挂载⽬录下的⽂件属主和组都是nobody,如果指定nfsvers=3则显⽰root。
如果要解除挂载,可执⾏命令:
umount /mnt/share
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
保存并重启机器看看。
测试验证
查看挂载结果,在客户端输⼊ df -h
⽂件系统容量已⽤可⽤已⽤% 挂载点
/dev/mapper/centos-root 18G 5.0G 13G 29% /
devtmpfs 904M 0 904M 0% /dev
tmpfs 916M 0 916M 0% /dev/shm
tmpfs 916M 9.3M 906M 2% /run
tmpfs 916M 0 916M 0% /sys/fs/cgroup
/dev/sda1 497M 164M 334M 33% /boot
tmpfs 184M 0 184M 0% /run/user/0
192.168.11.31:/data/share 18G 1.7G 16G 10% /mnt/share
看到最后⼀⾏了没,说明已经挂载成功了。接下来就可以在客户端上进⼊⽬录/mnt/share下,新建/删除⽂件,然后在服务端的⽬录/data/share查看是不是有效果了,同样反过来在服务端操作在客户端对应的⽬录下看效果。
总结
以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作具有⼀定的参考学习价值,如果有疑问⼤家可以留⾔交流,谢谢⼤家对的⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论