Centos搭建NFS磁盘共享

193 阅读5分钟

前言

NFS(Network File System,网络文件系统)是一种通过网络共享文件的协议,允许不同机器和操作系统之间方便地共享文件。通过NFS,我们可以将远程主机的共享目录挂载到本地,像操作本地磁盘一样操作远程文件,从而大大简化了跨系统文件管理的复杂性。

本文将详细介绍如何在 CentOS7 上安装和配置 NFS 服务器和客户端,实现文件共享。让我们一起来学习和操作吧!

准备

我们要实现的目标是:在 NFS 服务器上共享一个目录,在客户端上可以直接操作 NFS 服务器上的这个共享目录下的文件。 我们需要两台 CentOS7 机器,我们用虚拟机做测试,分别做 NFS 服务器和客户端,配置如下:

角色IP或者域名
NFS服务端master
NFS客户端node1

NFS 服务器配置

1. 安装 NFS 服务

首先使用 yum 安装 nfs 服务:

sudo yum -y install rpcbind nfs-utils

2. 创建共享目录

在服务器上创建共享目录,并设置权限。

sudo mkdir -p /data/share/
sudo chmod 755 -R /data/share/

3. 配置 NFS

[root@localhost ~]# sudo vim /etc/exports
#在文件最后添加一行:
/data/share/ node1(rw,no_root_squash,no_all_squash,sync)

这行代码的意思是把共享目录 / data/share / 共享给 node1 这个客户端 ip,后面括号里的内容是权限参数,其中:

  • rw 表示设置目录可读写。
  • sync 表示数据会同步写入到内存和硬盘中,相反 rsync 表示数据会先暂存于内存中,而非直接写入到硬盘中。
  • no_root_squash NFS 客户端连接服务端时如果使用的是 root 的话,那么对服务端分享的目录来说,也拥有 root 权限。
  • no_all_squash 不论 NFS 客户端连接服务端时使用什么用户,对服务端分享的目录来说都不会拥有匿名用户权限。

如果有多个共享目录配置,则使用多行,一行一个配置。保存好配置文件后,需要执行以下命令使配置立即生效:

sudo exportfs -r

4. 设置防火墙

如果你的系统没有开启防火墙,那么该步骤可以省略。

NFS 的防火墙特别难搞,因为除了固定的 port111、2049 外,还有其他服务如 rpc.mounted 等开启的不固定的端口,这样对防火墙来说就比较麻烦了。为了解决这个问题,我们可以设置 NFS 服务的端口配置文件。

修改/etc/sysconfig/nfs文件,将下列内容的注释去掉,如果没有则添加:

RQUOTAD_PORT=1001
LOCKD_TCPPORT=30001
LOCKD_UDPPORT=30002
MOUNTD_PORT=1002

保存好后,将端口加入到防火墙允许策略中。执行:

sudo 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 服务:

sudo systemctl start rpcbind
sudo systemctl start nfs

加入开机启动:

sudo systemctl enable rpcbind 
sudo systemctl enable nfs

nfs 服务启动后,可以使用命令 rpcinfo -p 查看端口是否生效。

服务器的后,我们可以使用 showmount 命令来查看服务端 (本机) 是否可连接:

[root@localhost ~]# showmount -e localhost
Export list for localhost:
/data/share master

出现上面结果表明 NFS 服务端配置正常。

客户端配置

1. 安装 rpcbind 服务

客户端只需要安装 rpcbind 服务即可,无需安装 nfs 或开启 nfs 服务。

sudo yum -y install rpcbind

2. 挂载远程 nfs 文件系统

查看服务端已共享的目录:

[root@localhost ~]# showmount -e master
Export list for master:
/data/share node1

建立挂载目录,执行挂载命令:

sudo mkdir -p /mnt/share
sudo mount -t nfs master:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3

如果不加 -onolock,nfsvers=3 则在挂载目录下的文件属主和组都是 nobody,如果指定 nfsvers=3 则显示 root。

如果要解除挂载,可执行命令:

sudo umount /mnt/share

3. 开机自动挂载

注意此种方式挂载,重启后才会生效

[root@localhost ~]# sudo vim /etc/fstab
#在文件最后添加一行:
master:/data/share /mnt/share/ nfs nolock,nfsvers=3,vers=3,_netdev 0 0

保存并重启机器看看。

测试验证

查看挂载结果,在客户端node1输入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 查看是不是有效果了,同样反过来在服务端操作在客户端对应的目录下看效果。

结语

这就是本文的全部内容,希望通过这篇文章,你能掌握在 CentOS7 上安装和配置 NFS 服务器和客户端的方法,实现文件共享。如果你在学习或工作中遇到问题,欢迎留言交流。感谢你对本文的阅读和支持!