Linux搭建NFS存储共享服务器

✍️Auth:运维笔记       Date:2021/07/16       Cat:Linux服务器       👁️:1,162 次浏览

NFS介绍:

NFS(Network File System)即网络文件系统,常用在负载均衡中,节省空间,远程挂载访问就像访问本地一样方便。同时共享文件系统,多台服务器无需每台都配置更新文件,一台NFS共享即可

模拟环境配置:系统:三台 CentOS 7
存储共享服务器:172.16.2.3 客户端(web):172.16.2.20/21/22
存储共享服务路径 /www. 访问ip为172.16.2.0/24 网段均可。

下载安装 rpcbind 和 nfs-utils

由于nfs端口不一,所以需要RPC来管理。相当于NFS相当于房源,RPC相当于中介。nfs将端口交给RPC来管理。所以需要安装rpcbind 。
在这里插入图片描述

服务端,客户端都需要安装(客户端有些系统如果默认支持nfs,则只需安装rpcbind):

yum -y install rpcbind nfs-utils

服务器端设置:

1 作为存储共享服务器,开机启动是必须的。

systemctl start rpcbind.service          #启动rpcbind服务
systemctl enable rpcbind.service          #开机启动rpcbind服务
systemctl start  nfs.service             #启动nfs服务
systemctl enable nfs.service             #开机启动rpcbind服务

2 准备一个共享目录。

作为web集群的共享目录,所以在根目录下创建/www目录。

mkdir /www

访问用户杂乱,给共享文件夹授权给nfsnobody:
用户nfsnobody在安装nfs时,已经自动创建,直接授权。

chown -R nfsnobody.nfsnobody /www

3 编辑nfs配置文件

在配置文件中/etc/exports 设置路径及相关用户权限。

vim /etc/exports

配置文件内容就一行,关键在于后面用户的权限参数

格式为 共享文件路径 访问IP(权限参数)

企业常用权限参数为root_squash,no_all_squash,只有root有权限,并映射为nfsnobody用户。

/www    172.16.2.0/24(rw,sync,root_squash)

相关参数设置参考如下:

rw                # 表示允许读写
ro                # 表示为只读,使存储目录权限位只读,使开发人员只能看  
sync            # 表示同步写入到内存与硬盘中
async            # 将数据先保存在内存缓冲区中,必要时才写入磁盘

no_root_squash    # 表示当客户机以root身份访问时赋予本地root权限(默认是root_squash)
root_squash        # 表示客户机用root用户访问该共享目录时,将root用户映射成匿名用户

all_squash        # 所有访问用户都映射为匿名用户或用户组
no_all_squash    # 对普通用户不做映射,无权限。root用户映射为nfsnobody

subtree_check(默认)    # 若输出目录是一个子目录,则nfs服务器将检查其父目录的权限
no_subtree_check        # 即使输出目录是一个子目录,nfs服务器也不检查其父目录的权限,这样可以提高效率
anonuid=xxx        # 指定NFS服务器/etc/passwd文件中的匿名用户的UID
anongid=xxx        # 指定NFS服务器/etc/passwd文件中的匿名用户的GID

更改完配置,重载配置:
这里也可重启服务,但用reload 重载更块,不用直接断开服务。

systemctl reload nfs.service   #重载服务
exportfs -v                    #查看已配置好的路径及相关配置


服务端配置完成。

客户端设置:

有几台web服务器,就几台都做同样的设置。
先测试两台ip: 172.16.2.20 172.16.2.21

1 创建需要挂载的路径:

创建目录:

mkdir -p /www/html

2 查看服务器共享目录:

showmount -e 172.16.2.3

3 挂载共享目录/www至本地/www/html目录

mount -t nfs 172.16.2.3:/www /www/html

挂载完成 df -h 查看是否挂载成功。


上图显示已挂载成功!!!

4 客户端创建测试文件:

172.16.2.20客户端/www/html 创建一个文件text.txt 并输入内容123。

echo "123" >> /www/html/text.txt

同样可在172.16.2.21客户端创建一个111.txt文件。

touch /www/html 111.txt

创建成功后,在存储共享服务器共享目录/www,及每台客户端挂载目录/www/html目录,都可看到这刚才创建的两个文件,搭建成功。

实现开机自动挂载共享目录

在客户端设置开机自动挂载

方法一:利用开机脚本 rc.local

echo "mount -t nfs 172.16.2.3:/www /www/html" >>/etc/rc.local

方法二. 利用fstab文件

vim /etc/fstab

输入IP,路径即可

172.16.2.3:/www   /www/html   nfs   defaults    0 0

到此nfs共享存储服务器搭建完成!!!

打赏作者

Linux搭建NFS存储共享服务器》有2个想法

  1. Pingback引用通告: inotify+rsync实现实时监控备份 - 运维笔记(ywbj.cc)

  2. Pingback引用通告: 常用基础web架构图及配置 - 运维笔记(ywbj.cc)

发表评论