首页 技术综合正文

搭建存储服务器(网络存储服务器搭建方案)

hezhisheng026 技术综合 2022-11-07 17:00:01 188 0

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共享存储服务器搭建完成!!!

版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

本文链接:https://www.16i.cc/post/2154.html