NFS文件共享服务搭建

文章目录

    • NFS介绍
      • 特点
      • 用途
    • NFS版本
    • NFS安装
      • 0. 安装规划
      • 1. 安装NFS服务
      • 2. 启动并启用服务
      • 3. 创建共享目录
      • 4. 配置NFS共享
      • 5. 应用NFS配置
      • 6. 防火墙设置
      • 7. 验证NFS服务
      • 8. 客户端挂载
      • 9. 验证挂载
      • 10. 客户端卸载nfs挂载
      • 11. 自动挂载
    • 参考文章

NFS介绍

在这里插入图片描述

NFS(Network File System)是一个允许网络中的计算机之间共享文件的系统。它最初由Sun Microsystems开发,现在广泛应用于多种操作系统中。NFS允许用户像访问本地文件一样访问存储在远程服务器上的文件。NFS服务的实现依赖于RPC(Remote Procedure Call,远程过程调用)机制,以完成远程到本地的映射过程。

特点

  1. 跨平台支持:NFS最初是为Unix系统设计的,但现在已经扩展到支持多种操作系统,包括Linux、Windows、Mac OS等。

  2. 易于配置:NFS服务器的设置相对简单,只需要配置/etc/exports文件并启动服务即可。

  3. 数据一致性:NFS提供了数据一致性的保证,确保文件在远程访问时的完整性。

  4. 性能:NFS的性能取决于网络速度和服务器性能,通常适用于局域网内的文件共享。

  5. 版本多样:NFS有多个版本,包括NFSv2、NFSv3、NFSv4等,每个版本都有其特定的性能和安全特性。

  6. 安全性:NFSv4引入了更强的安全性,包括Kerberos认证和加密通信。

  7. 灵活性:NFS允许管理员通过配置文件和权限设置来控制对共享文件的访问。

  8. 去中心化:NFS允许多个客户端同时访问和修改文件,而不需要集中式管理。

用途

  1. 文件共享:NFS主要用于在不同计算机之间共享文件和目录。

  2. 数据备份:NFS可以用于远程备份数据,确保数据的安全性和可恢复性。

  3. 分布式计算:在分布式计算环境中,NFS允许应用程序访问存储在远程服务器上的数据。

  4. 多媒体共享:NFS可以用于共享音频、视频和其他多媒体文件。

  5. 开发和测试:开发人员可以使用NFS在不同的开发环境中共享代码和资源。

  6. 虚拟化环境:在虚拟化环境中,NFS可以用于虚拟机之间的文件共享。

  7. 教育和研究机构:教育机构和研究机构经常使用NFS来共享研究数据和学术资源。

  8. 企业内部网:企业可以使用NFS来构建内部文件共享系统,提高工作效率。

NFS是一种成熟且广泛使用的文件共享技术,适用于需要跨网络共享文件的各种场景。随着技术的发展,NFS也在不断地更新和改进,以满足现代网络环境的需求。

NFS版本

在CentOS系统中构建NFS文件共享服务需要安装nfs-utilsrpcbind

nfs-utils 是一个提供NFS服务的软件包,它包含了NFS服务器和客户端所需的工具和守护进程。nfs-utils 允许系统管理员配置和管理NFS共享,以及挂载和访问远程NFS共享。

rpcbind,也称为portmap,是一个RPC服务,它将RPC程序号映射到网络上的端口号。RPC服务需要一个监听特定端口(默认为111)的守护进程,以便客户端可以查询RPC服务的端口号。当NFS服务启动时,它会随机选择一些端口,并使用rpcbind来注册这些端口,这样客户端就可以通过查询rpcbind来找到正确的端口进行连接。

工作原理概述如下:

  1. NFS服务启动后,会随机选择一些端口用于文件共享服务。
  2. NFS服务将这些端口信息注册到rpcbind服务。
  3. rpcbind服务监听111端口,等待客户端的请求。
  4. 客户端通过rpcbind服务查询特定NFS服务的端口号。
  5. rpcbind服务响应客户端请求,提供NFS服务的端口信息。
  6. 客户端使用这些端口信息连接到NFS服务,并进行文件操作。

NFS服务的配置通常在 /etc/exports 文件中进行,定义了哪些目录可以被共享,以及共享的权限和选项。客户端可以使用 mount 命令挂载NFS共享,就像挂载本地文件系统一样。

使用 sudo yum install -y nfs-utils rpcbind 命令安装的 nfs-utilsrpcbind 的具体版本取决于你的CentOS系统的版本以及可用的软件包仓库。yum 包管理器会根据你的系统配置和仓库中的可用软件包来安装最新或默认版本的这些工具。

要查看已安装的 nfs-utilsrpcbind 的版本,你可以使用 yuminfo 命令或者 rpm 命令。以下是如何查看这些包的版本信息的示例:

  1. 使用 yum 命令查看包信息:
sudo yum info nfs-utils rpcbind

这个命令将显示已安装的 nfs-utilsrpcbind 包的详细信息,包括版本号。

  1. 使用 rpm 命令查看包信息:
rpm -q nfs-utils rpcbind

这个命令将直接显示已安装的包的版本号。

请注意,如果你需要特定版本的 nfs-utilsrpcbind,你可以指定版本号进行安装,例如:

sudo yum install -y nfs-utils-版本号 rpcbind-版本号

替换 版本号 为你需要的特定版本号。如果你不确定可用的版本,可以先使用 yum search 命令来查找可用的版本:

yum search nfs-utils rpcbind

这将列出所有可用的 nfs-utilsrpcbind 版本,然后你可以选择一个特定的版本进行安装。

NFS安装

CentOS系统中构建NFS文件共享服务主要涉及以下几个步骤:

0. 安装规划

以三台服务器为例, node1, node2, node3, 其中 node1NFS服务端, node2node3 分别为NFS客户端

在这里插入图片描述

服务器角色目录
node1NFS服务端/data/server/nfsshare
node2NFS客户端/data/client/nfsshare
node3NFS客户端/data/client/nfsshare

1. 安装NFS服务

首先,需要在服务器上安装NFS服务。打开终端并执行以下命令:

sudo yum install -y nfs-utils rpcbind

2. 启动并启用服务

安装完成后,启动并设置NFS服务和rpcbind服务开机自启:

sudo systemctl start rpcbind
sudo systemctl enable rpcbind
sudo systemctl start nfs-server
sudo systemctl enable nfs-server

3. 创建共享目录

创建一个目录作为NFS共享目录,所有客户端将能够访问此目录:

sudo mkdir -p /data/server/nfsshare

4. 配置NFS共享

编辑/etc/exports文件,添加你想要共享的目录及其权限:

sudo vim /etc/exports

在文件中添加以下行(假设我们共享/nfsshare目录):

/data/server/nfsshare  *(rw,sync,no_root_squash,no_subtree_check)

这里的配置项说明:

  • rw:读写权限。
  • sync:同步写入磁盘。
  • no_root_squash:允许远程root用户具有本地root用户的权限。
  • no_subtree_check:不检查父目录权限。

5. 应用NFS配置

保存并关闭/etc/exports文件后,运行以下命令来应用配置:

sudo exportfs -ra

6. 防火墙设置

如果服务器上启用了防火墙,需要允许NFS服务的端口。默认情况下,NFS使用2049端口,以及111端口用于RPC服务:

sudo firewall-cmd --permanent --add-service=nfs
sudo firewall-cmd --permanent --add-service=mountd
sudo firewall-cmd --permanent --add-service=rpc-bind
sudo firewall-cmd --reload

7. 验证NFS服务

使用以下命令检查NFS服务的状态:

sudo systemctl status nfs-server
sudo systemctl status rpcbind

8. 客户端挂载

首先,需要在客户端上安装nfs-utils rpcbind。打开终端并执行以下命令:

sudo yum install -y nfs-utils rpcbind
  • nfs-utils:同样用于NFS客户端,以便挂载和访问远程NFS共享。
  • rpcbind:虽然rpcbind主要用于服务端,但客户端也需要它来查询服务端的RPC服务端口号。

然后,在客户端上,你可以使用以下命令挂载NFS共享:

sudo mount -t nfs <服务器IP>:/data/server/nfsshare /data/client/nfsshare

<服务器IP>替换为NFS服务器的IP地址,/data/client/nfsshare为客户端上的挂载点。

9. 验证挂载

检查挂载是否成功:

mount | grep nfs

如果一切正常,你应该能看到挂载点的信息。

10. 客户端卸载nfs挂载

umount /data/client/nfsshare

/data/client/nfsshare为客户端上的挂载点。

11. 自动挂载

为了在系统启动时自动挂载NFS共享,你可以将挂载命令添加到/etc/fstab文件中。

以上就是在CentOS系统上构建NFS文件共享服务的基本步骤。根据你的具体需求,可能还需要进行一些额外的配置和调整。

参考文章

文件服务器之一:nfs服务部署搭建
NFS服务搭建
快速学会k8s数据存储、数据卷、EmptyDir、HostPath、NFS、PV、PVC…
Setup a NFS Server with Docker

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/36333.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

golang 如何判断当前是否是运行单元测试?

我们在go的模块化开发的时候&#xff0c;运行模块里面的单元测试时&#xff0c;当前整个模块的 init 函数都会被执行&#xff0c;在某些情况下我们运行独立的单元测试并不需要执行其他文件里面的init函数&#xff0c;这时就需要判断当前是否是在运行单元测试&#xff0c;判断方…

linux的常用系统维护命令

1.ps显示某个时间点的程序运行情况 -a &#xff1a;显示所有用户的进程 -u &#xff1a;显示用户名和启动时间 -x &#xff1a;显示 没有控制终端的进程 -e &#xff1a;显示所有进程&#xff0c;包括没有控制终端的进程 -l &#xff1a;长格式显示 -w &#xff1a;宽…

jEasyUI 自定义排序

jEasyUI 自定义排序 jEasyUI 是一个基于 jQuery 的框架,用于创建富交互的网页界面。它提供了一系列的组件,如布局、窗口、数据网格等,使得用户能够轻松地构建功能强大的用户界面。在数据网格(datagrid)组件中,排序功能是一个非常重要的特性,它允许用户根据列的值对数据…

k8s部署mongodb副本高可用集群

此版本的NFS为单点,仅为练习使用,生产环境建议使用cephfs的卷类型,避免单点。或者通过keepalived加Sersync的方案对NFS作容灾处理即可用于生产环境。当然,对于开发或测试环境,方便起见,直接使用单点的NFS加mongodb statefulSet方案是最为清晰简便的。 mongodb集群部署分…

66.前端接口调用返回400的错误

错误代码400通常表示由于无效的请求导致服务器无法处理请求。这可能是由于以下原因之一&#xff1a; 1.语法错误&#xff1a;客户端发送的请求可能存在语法错误&#xff0c;例如缺少必需的参数、格式不正确等。 2.未授权&#xff1a;如果API需要认证&#xff0c;而客户端没有提…

代谢组数据分析十一:典型相关分析

欢迎大家关注全网生信学习者系列: WX公zhong号:生信学习者Xiao hong书:生信学习者知hu:生信学习者CDSN:生信学习者2介绍 典型相关分析(Canonical Correlation Analysis,简称CCA)是一种统计方法,用于探索两组变量之间的线性关系。与主成分分析(PCA)不同,PCA是在同一…

Gemma 2大模型:性能更优,效率更高

当地时间6月27日&#xff0c;谷歌正式发布了在一个月前的I/O开发者大会上预告过的Gemma 2大模型。这款新模型相较于第一代Gemma模型&#xff0c;在性能和推理效率上都有了显著的提升&#xff0c;为AI领域带来了新的突破。 据谷歌介绍&#xff0c;Gemma 2模型包括9B和27B两种参…

创建github个人博客

文章目录 安装Hexo安装git安装Node.js安装 Hexo git配置SSH key配置ssh 搭建个人博客新建博客生成静态网页 本文主要参考 【保姆级】利用Github搭建自己的个人博客&#xff0c;看完就会 安装Hexo 参考官方文档&#xff1a;https://hexo.io/zh-cn/docs/ Hexo 是一个快速、简洁且…

探索WebKit的守护神:深入Web安全策略

探索WebKit的守护神&#xff1a;深入Web安全策略 在数字化时代&#xff0c;网络已成为我们生活的一部分&#xff0c;而网页浏览器作为我们探索网络世界的窗口&#xff0c;其安全性至关重要。WebKit作为众多流行浏览器的内核&#xff0c;例如Safari&#xff0c;其安全性策略是保…

【其他】这阵子虚拟机编译和重启次数太多后果

1、开始蓝屏的次数没有&#xff0c;随着VM的Ubuntu每天大量的编译&#xff0c;代码里边各种加while(1)&#xff0c;估计是加重了宿主机的负担吧&#xff0c;宿主机后来&#xff08;大概是十天前&#xff09;是一天蓝屏1次&#xff1b;慢慢增加现在是一天大概蓝屏6次&#xff0c…

微服务实战系列之云原生

前言 话说博主的微服务实战系列从去年走到今天&#xff0c;已过去了半年多了。本系列&#xff0c;博主主要围绕微服务实践过程中的主要组件或工具展开介绍。其中基本覆盖了我们项目或产品研发过程中&#xff0c;经常使用的中间件或第三方工具。至此&#xff0c;该系列也该朝着…

2024年河北省计划招聘“特岗计划”教师2300名

2024年河北省计划招聘“特岗计划”教师2300名 报名时间&#xff1a;6月28日9:00至7月2日18:00 笔试准考证打印&#xff1a;7月11日-7月13日 笔试时间&#xff1a;7月14日上午9:00-11:30 面试时间&#xff1a;8月3日至8月5日 报名网站&#xff1a;河北教师教育网 报名照规格&…

Spring Boot中使用Actuator监控应用状态

Spring Boot中使用Actuator监控应用状态 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天我们将深入探讨如何在Spring Boot应用中使用Actuator来监控和管理应…

2024全新【大模型学习路径导航】从入门到精通的全面规划

引言 随着人工智能技术的迅猛发展&#xff0c;大模型成为了引领技术变革的关键力量。无论你是对大模型领域感兴趣的初学者&#xff0c;还是希望深化理解并应用大模型的开发者&#xff0c;这份精心策划的学习路径将为你提供从零基础到精通的全面指导。 第一阶段&#xff1a;基…

[机器学习]-1 概要介绍

1 理论来源 机器学习理论是参照人类学习链条&#xff1a;DIKIW模型&#xff08;数据-信息-知识-智能-智慧&#xff09; -数据: 原始的、未经处理的事实和数字。 -信息: 经过处理、整理和结构化的数据&#xff0c;具有意义和上下文。 -知识: 由信息构建而成的模式和规则。 -智能…

Pytest--安装与入门

pytest是一个能够简化成测试系统构建、方便测试规模扩展的框架&#xff0c;它让测试变得更具表现力和可读性–模版代码不再是必需的。只需要几分钟的时间&#xff0c;就可以对你的应用开始一个简单的单元测试或者复杂的功能测试。 1. 安装pytest pip install -U pytest检查版…

使用Java编写网络爬虫

使用Java编写网络爬虫 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 网络爬虫是一种自动化程序&#xff0c;用于从互联网上获取信息并收集数据。在Java中编写…

基于Java影院管理系统设计和实现(源码+LW+调试文档+讲解等)

&#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN作者、博客专家、全栈领域优质创作者&#xff0c;博客之星、平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌&#x1f497; &#x1f31f;文末获取源码数据库&#x1f31f;感兴趣的可以先收藏起来&#xff0c;还…

centos7 samba服务器配置

centos7 samba服务器配置 以下是一个基本的Samba服务器配置示例&#xff0c;用于在CentOS 7上设置一个简单的文件共享&#xff1a; 安装Samba服务&#xff1a; sudo yum install samba samba-client samba-common 备份Samba默认配置文件&#xff1a; sudo cp /etc/samba/smb…