CentOS 7中搭建NFS文件共享存储服务的完整步骤

目录

一、NFS服务器配置

1.安装NFS服务

2.创建共享目录

3.配置NFS

4.设置防火墙

5.启动服务

二、客户端配置

1.安装rpcbind服务 (showmount是nfs的命令,无需开启nfs服务)

2.挂载远程nfs文件系统

3.开机自动挂载

NFS(Network File System)意为网络文件系统,它最大的功能就是可以通过网络,让不同的机器不同的操作系统可以共享彼此的文件。简单的讲就是可以挂载远程主机的共享目录到本地,就像操作本地磁 盘一样,非常方便的操作远程文件。
准备
我们需要两台 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.创建共享目录

在服务器上创建共享目录,并设置权限。
1 mkdir /data/share/
2 chmod 755 -R /data/share/

3.配置NFS

nfs 的配置文件是 /etc/exports ,在配置文件中加入一行:
1 /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 客户端连接服务端时使用什么用户,对服务端分享的目录来说都不会拥有匿名用户权限。
如果有多个共享目录配置,则使用多行,一行一个配置。保存好配置文件后,需要执行以下命令使配置立即生效:

此命令需要保证 nfs 服务启动
systemctl start nfs
1 exportfs -r

4.设置防火墙

如果你的系统没有开启防火墙,那么该步骤可以省略。
NFS 的防火墙特别难搞,因为除了固定的 port111 2049 外,还有其他服务如 rpc.mounted 等开启的不 固定的端口,这样对防火墙来说就比较麻烦了。为了解决这个问题,我们可以设置NFS 服务的端口配 置文件。
修改 /etc/sysconfig/nfs 文件,将下列内容的注释去掉,如果没有则添加:
1 RQUOTAD_PORT=1001
2 LOCKD_TCPPORT=30001
3 LOCKD_UDPPORT=30002
4 MOUNTD_PORT=1002
保存好后,将端口加入到防火墙允许策略中。执行:
1 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 --addport=1002/udp --add-port=30001/tcp --add-port=30002/udp --permanent
2 firewall-cmd --reload

5.启动服务

按顺序启动 rpcbind nfs 服务:
1 systemctl start rpcbind
2 systemctl start nfs
加入开机启动:
1 systemctl enable rpcbind
2 systemctl enable nfs
nfs服务启动后,可以使用命令 rpcinfo -p 查看端口是否生效。
我们可以使用 showmount 命令来查看服务端 ( 本机 ) 是否可连接:
1 [root@localhost ~]# showmount -e localhost
2 Export list for localhost:
3 /data/share 192.168.11.34
出现上面结果表明NFS 服务端配置正常。

二、客户端配置

1.安装rpcbind服务 showmountnfs的命令,无需开启nfs服务)

1 yum -y install rpcbind nfs-utils

2.挂载远程nfs文件系统

查看服务端已共享的目录 :
1 [root@localhost ~]# showmount -e 192.168.11.31
2 Export list for 192.168.11.31:
3 /data/share 192.168.11.34
建立挂载目录,执行挂载命令:
1 mkdir -p /mnt/share
2 mount -t nfs 192.168.11.34:/data/share /mnt/share/ -o nolock,nfsvers=3,vers=3
如果不加 -onolock,nfsvers=3 则在挂载目录下的文件属主和组都是 nobody ,如果指定 nfsvers=3 则显示 root。
如果要解除挂载,可执行命令:
1 umount /mnt/share

3.开机自动挂载

如果按本文上面的部分配置好, NFS 即部署好了,但是如果你重启客户端系统,发现不能随机器一起挂载,需要再次手动操作挂载,这样操作比较麻烦,因此我们需要设置开机自动挂载。
我们不要把挂载项写到/etc/fstab 文件中,因为开机时先挂载本机磁盘再启动网络,而 NFS 是需要网络启动后才能挂载的,所以我们把挂载命令写入到/etc/rc.d/rc.local 文件中即可
1 [root@localhost ~]# cat /etc/fstab
2
3 #
4 # /etc/fstab
5 # Created by anaconda on Sun Aug 14 19:31:17 2022
6 #
7 # Accessible filesystems, by reference, are maintained under '/dev/disk'
8 # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
9 #
10 UUID=b0ab1193-1995-49ad-9290-d0c987553c59 / xfs defaults 0 0
11 UUID=01a4623c-d0a9-4eb5-9a0c-443ce611192f /boot xfs defaults 0 0
12 UUID=b4b71912-0998-444a-a3f9-ca80e37307c7 swap swap defaults 0 0
13 192.168.59.130:/data/share /mnt/share nfs defaults 0 0
保存并重启机器看看。
测试验证
查看挂载结果,在客户端输入 df -h
1 文件系统 容量 已用 可用 已用% 挂载点
2 /dev/mapper/centos-root 18G 5.0G 13G 29% /
3 devtmpfs 904M 0 904M 0% /dev
4 tmpfs 916M 0 916M 0% /dev/shm
5 tmpfs 916M 9.3M 906M 2% /run
6 tmpfs 916M 0 916M 0% /sys/fs/cgroup
7 /dev/sda1 497M 164M 334M 33% /boot
8 tmpfs 184M 0 184M 0% /run/user/0
9 192.168.11.31:/data/share 18G 1.7G 16G 10% /mnt/share
看到最后一行了没,说明已经挂载成功了。接下来就可以在客户端上进入目录 /mnt/share 下,新建 / 删除文件,然后在服务端的目录/data/share 查看是不是有效果了,同样反过来在服务端操作在客户端对应的目录下看效果。
  • 22
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值