linux下nfs配置及远程挂载(Linux搭建NFS存储共享服务器)

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 。

linux下nfs配置及远程挂载(Linux搭建NFS存储共享服务器)(1)

服务端,客户端都需要安装(客户端有些系统如果默认支持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 #查看已配置好的路径及相关配置

linux下nfs配置及远程挂载(Linux搭建NFS存储共享服务器)(2)

服务端配置完成。

客户端设置:

有几台web服务器,就几台都做同样的设置。

先测试两台ip: 172.16.2.20 172.16.2.21

1) 创建需要挂载的路径:

创建目录:

mkdir -p /www/html

2) 查看服务器共享目录:

showmount -e 172.16.2.3

linux下nfs配置及远程挂载(Linux搭建NFS存储共享服务器)(3)

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

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

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

linux下nfs配置及远程挂载(Linux搭建NFS存储共享服务器)(4)

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

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`目录,都可看到这刚才创建的两个文件,搭建成功。

linux下nfs配置及远程挂载(Linux搭建NFS存储共享服务器)(5)

linux下nfs配置及远程挂载(Linux搭建NFS存储共享服务器)(6)

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

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

方法一:利用开机脚本 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共享存储服务器搭建完成!!!

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页