NFS介绍及服务器搭建

这篇具有很好参考价值的文章主要介绍了NFS介绍及服务器搭建。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、NFS 简介

NFS,英文全称 Network File System,主要功能:通过网络,让不同的机器、不同的操作系统可以共享文件。类似windows的共享文件夹

​ NFS服务器共享本机目录,客户端机器挂载该目录后,就可以像自己本机的目录一样使用,相当便利;操作远程目录就像操作本地目录;

官网:https://nfs.sourceforge.net/
文档:https://nfs.sourceforge.net/nfs-howto/index.html
使用场景:NFS适用于在中小型项目中,作为文件服务器使用;在大型项目中,建议使用真正的分布式存储,如:Ceph; NFS还是有单节点问题;替换FTP服务器还是没问题的;比上不足比下有余
NFS介绍及服务器搭建

二、NFS服务器搭建(CentOS)

假设有如下三台服务器
192.168.1.100 :作为NFS服务端
192.168.1.101 :作为NFS客户端1
192.168.1.102 :作为NFS客户端2

1. 服务端搭建(192.168.1.100 服务器)
1.1. 安装 nfs,rpc 服务
yum install -y rpcbind
yum install -y nfs-utils
1.2. 创建共享目录
  • test1共享目录
#目录根据自身情况自行选择,这里仅做演示
mkdir /home/nfs/disk-test1
chmod 777 /home/nfs/disk-test1

777含义:1-可执行权限、2-可写权限、4-可读权限;7=4+2+1,表示所有权限;
第一个7代表当前用户权限,第二个代表同组用户权限,第三个代表其他用户权限;
权限可以根据实际情况设置

  • test2共享目录
mkdir /home/nfs/disk-test2
chmod 777 /home/nfs/disk-test2
1.3. 修改nfs配置文件
#如果没有,则自行创建即可
vim /etc/exports

在文件中添加

#也可用192.168.1.* ,用于访问控制,只有在该IP段的机器才可以访问,* 不做ip控制
#ip地址与(之间不能有空格,否则会出现只读异常
/home/nfs/disk-test1 192.168.1.0/24(rw,sync,no_subtree_check,no_root_squash)
/home/nfs/disk-test2 *(rw,sync,no_subtree_check,no_root_squash)
参数 作用
ro 只读(read only)
rw 读写(read write)
root_squash 当NFS客户端以root管理员访问时,映射为NFS服务器的匿名用户(nobody)
no_root_squash 当NFS客户端以root管理员访问时,映射为NFS服务器的root管理员
all_squash 无论NFS客户端使用什么账户访问,均映射为NFS服务器的匿名用户
sync NFS先写入缓存(内存),再同步到稳定存储(硬盘),sync表示写入硬盘成功后,才告诉客户端写入成功,保证不丢失数据,效率偏低
async 写入缓存后就通知客户端写入成功,不关心硬盘是否成功;这样效率更高,但可能会丢失数据
secure NFS客户端必须使用NFS保留端口(通常是1024以下的端口),默认选项
insecure 允许NFS客户端不使用NFS保留端口(通常是1024以上的端口)
anonuid 指定匿名用户的uid,默认指向nobody
anongid 指定匿名用户的gid, 即组id,默认指向nobody组

客户机和NFS服务器之间人员映射规则:linux系统有严格的人员权限控制,那么客户机用什么角色访问NFS服务器呢?这就有一套映射规则

  • root用户的映射由配置决定(root_squash);
  • 非root用户,先映射为有相同UID的,如果没有,则映射为匿名用户nobody,即:两台机器上,UID相同的互为映射,不同的映射为nobody;
1.4. 开启服务
  • 启动服务
#启动rpc服务
systemctl start rpcbind 
#启动nfs服务
systemctl start nfs-server # nfs服务名称和版本相关,有的版本是 nfs

查看是否成功运行

showmount -e 
#执行结果如下代表成功
Export list for localhost:
/home/nfs/disk-test1 192.168.1.0/24
/home/nfs/disk-test2 *
  • 开机启动
systemctl enable rpcbind
systemctl enable nfs-server
  • 关闭防火墙
#由于nfs使用端口不固定,因此需要关闭防火墙,如果防火墙未开启,可忽略此步
systemctl stop firewalld    #关闭防火墙
systemctl disable firewalld #关闭开机启动
systemctl status firewalld  #查看防火墙状态

启动服务后,如果再次修改了/etc/exports,可重启服务systemctl restart nfs-server或者执行 exportfs -rv,使配置生效

2. 客户端挂载

客户端安装

yum install -y nfs-utils

客户端查看连通性并创建本地用于挂载的目录

showmount -e 192.168.1.100
#执行结果
Export list for 192.168.1.100:
/home/nfs/disk-test1 192.168.1.0/24
/home/nfs/disk-test2 *

创建本地目录用于挂载(建议使用相同目录结构,这里只是演示)

mkdir /nfs1
2.1 使用mount命令挂载
#挂载
mount  -t nfs  192.168.1.100:/home/nfs/disk-test1 /nfs1 
#卸载
umount /nfs1

但这种方式有个问题,重启后会失效,需要重新执行挂载命令,在生产环境,不建议使用该方式

2.2 fstab挂载(推荐)
vim /etc/fstab
#在该文件中挂载,使系统每次启动时都能自动挂载
#在文件中添加挂载内容
192.168.1.100:/home/nfs/disk-test1 /nfs1       nfs    defaults 0 0
#保存退出 各列含义可自行百度,网上都有介绍
mount -a   #使文件/etc/fstab生效
3. 检查
  • 在客户端查看挂载情况
df -Th

NFS介绍及服务器搭建

  • 向客户端挂载目录存入文件,到服务端查看情况

三、固定端口部署(非必须)

在一些复杂场景下,有时是不能关闭防火墙的,这就需要把nfs部署为固定端口,并添加防火墙规则
场景举例:

  1. nfs服务器上部署有docker容器,docker的网络映射依赖防火墙,如果不开启防火墙,容器会启动失败;
  2. 在做等保测评时,要求服务器必须开启防火墙
  3. 生产环境不建议关闭防火墙;
1. 查看服务端nfs端口使用情况
rpcinfo -p #查看当前服务以及端口

NFS介绍及服务器搭建
nfs服务需要开启 mountd,nfs,nlockmgr,portmapper,rquotad这5个服务,nfs 和 portmapper两个服务是固定端口,nfs为2049,portmapper为111。其他的3个服务是随机端口

2.配置NFS固定端口
2.1. 在/etc/sysconfig/nfs中添加以下设置,端口可自行选择
RQUOTAD_PORT=30001
LOCKD_TCPPORT=30002
LOCKD_UDPPORT=30002
MOUNTD_PORT=30003
STATD_PORT=30004
2.2. 重启rpc、nfs的配置与服务
systemctl restart rpcbind
systemctl restart nfs-server 
2.3. 在/etc/modprobe.d/lockd.conf中添加以下设置
options lockd nlm_tcpport=30002
options lockd nlm_udpport=30002
2.4. 重新加载NFS配置和服务
systemctl restart nfs-config
systemctl restart nfs-idmap
systemctl restart nfs-lock
systemctl restart nfs-server
2.5. 查看端口情况
rpcinfo -p

NFS介绍及服务器搭建文章来源地址https://www.toymoban.com/news/detail-462608.html

2.6. 添加防火墙规则
firewall-cmd --add-port=30002/tcp --add-port=30002/udp --permanent
firewall-cmd --add-port=111/tcp --add-port=2049/tcp --permanent
……
#依次把所有用到的端口和协议都添加完成,这里不在赘述,添加完成后,重新加载

firewall-cmd --reload

到了这里,关于NFS介绍及服务器搭建的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 搭建web服务器和NFS服务器

    网站需求: 1.基于域名www.openlab.com可以访问网站内容为 welcome to openlab!!! 2.给该公司创建三个子界面分别显示学生信息,教学资料和缴费网站,基于www.openlab.com/student/ 网站访问学生信息,www.openlab.com/data/网站访问教学资料www.openlab.com/money/网站访问缴费网站。 3.要求 (1)学生

    2024年01月23日
    浏览(52)
  • Linux上的NFS服务器搭建

    目录 一.服务器端搭建 二.客户端搭建 Shareserver NFS服务器: 1:给NFS服务器一个ip地址 2:修改主机名 3:修改主机映射关系 4:测试联通性 5:查询是否有rpcbind及nfs-utils,若无则安装 6:查询是否有rpcbind及nfs-utils状态,若关闭则开启 7:关闭防火墙 8:创建共享目录/share,并在其共享目录中

    2024年02月07日
    浏览(56)
  • linux主机搭建NFS服务器

    NFS(Network File System,网络文件系统) 它允许网络中的计算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系列操作系统上使用。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。 NFS服务器

    2024年01月16日
    浏览(51)
  • nfs服务器的描述,搭建和使用

    前言 这是我在这个网站整理的笔记,关注我,接下来还会持续更新。 作者:RodmaChen NFS概述 NFS(Network File System)是一种基于网络的文件系统协议,它允许不同的计算机系统通过网络共享文件和目录。本文将介绍NFS的工作原理、优缺点以及挂载后客户端创建文件服务端也会出

    2024年02月15日
    浏览(57)
  • docker搭建NFS服务器(超简单)

    docker 安装 NFS服务端与客户端 一:服务端: 1.下载镜像到本地。 地址:https://www.aliyundrive.com/s/LUQ4A4yuZcY 2.启动镜像 解压镜像 docker load docker-nfs-server.tar 启动成功如图所示: 备注:docker启动成功,意味着将系统 /home/docker/nfs01 下的文件挂载到了 docker内部nfs目录下。 如图所示(

    2024年02月09日
    浏览(53)
  • Ubantu搭建NFS服务器共享文件

    搭建一台NFS服务器为局域网中的用户提供文件共享,NFS服务器要求如下: 1.将本地文件系统的/home/share目录共享,192.168.61.100与192.168.61.200两个客户机对该目录具有读写限权,而192.168.61.0/24网段内的其他客户机对该目录具有只读限权。(IP地址可根据自己虚拟机的地址调整)

    2024年02月08日
    浏览(59)
  • Windows server 2019搭建NFS服务器

    1、NFS服务端配置 安装服务 配置NFS共享文件夹 选择服务器和此共享的路径(选择我们创建的磁盘) 创建共享名称 指定身份验证方法 设置共享权限-指定我要授权访问的主机 确认选择没有问题点击创建 可以看到我们刚才创建好的共享文件夹 2、NFS客户端配置 NFS客户端安装 挂

    2024年02月11日
    浏览(45)
  • 【Linux网络服务】Centos7搭建nfs文件共享服务器

    1.NFS介绍 2.环境准备 3.在A服务端机器安装nfs-utils和rpcbind包 4.启动rpcbind检查是否启动了rpcbind服务并监听111端口 5.配置NFS服务的配置文件,参数配置:vi /etc/exports 数据同步与数据异步的区别 数据同步:当系统从内存中向磁盘中持久化数据时,同步发送表示只有当内存中的数据

    2024年02月06日
    浏览(63)
  • 为openlab搭建网站和架设一台NFS服务器

    给该公司创建三个子界面分别显示学生信息,教学资料和缴费网站,基于www.openlab.com/student网站访问学生信息,www.openlab.com/data网站访问教学资料,www.openlab.com/money网站访问缴费。 要求: (1)学生信息网站只有song和tian两人可以访问,其他用户不能访问。 (2)访问缴费网站

    2024年01月16日
    浏览(49)
  • 【操作系统】Centos7搭建nfs文件共享服务器实战

    1.NFS介绍 2.环境准备 3.在A服务端机器安装nfs-utils和rpcbind包 4.启动rpcbind检查是否启动了rpcbind服务并监听111端口 5.配置NFS服务的配置文件,参数配置:vi /etc/exports 数据同步与数据异步的区别 数据同步:当系统从内存中向磁盘中持久化数据时,同步发送表示只有当内存中的数据

    2024年02月07日
    浏览(57)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包