NSF服务器

2023-11-11 19:44
文章标签 服务器 nsf

本文主要是介绍NSF服务器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.简介

1.1 NFS背景介绍

        NFS是一种古老的用于在UNIX/Linux主机之间进行文件共享的协议。它古老到你必须穿着白大补才能接近一台计算机的年代。在那个年代,所有的联网计算机都被认为是可信的,而不像现今这样,任何人都有多种多样方法能连接到你的计算机。因此,NFS在开发的时候专注于快速及易用的文件共享,而忽视了其安全性设计
        NFS(Network File System,网络文件系统)是FreeBSD支持的文件系统中的一种,它允许网络中的计算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系列操作系统上使用。
        NFS服务器可以让PC将网络中的NFS服务器共享的目录挂载到本地端的文件系统中,而在本地端的系统中看来,那个远程主机的目录就好像是自己的一个磁盘分区一样。
        由于NFS支持的功能比较多,而不同的功能都会使用不同的程序来启动,每启动一个功能就会启用一些端口来传输数据,因此NFS的功能所对应的端口并不固定,而是随机取用一些未被使用的小于1024的端口用于传输。但如此一来就会产生客户端连接服务器的问题,因为客户端需要知道服务器端的相关端口才能够连接。此时就需要RPC
        RPC(Remote Procedure Call,远程过程调用):由于服务器在启动NFS时会随机选取数个端口号,并主动向RPC注册,所以RPC知道每个NFS功能所对应的端口号,RPC将端口号通知给客户端,让客户端可以连接到正确的端口上去。RPC采用固定端口号port 111来监听客户端的需求并向客户端响应正确的端口号。

        注:在启动NFS之前,要先启动RPC,否则NFS会无法向RPC注册。另外,RPC若重新启动,原来注册的数据会消失不见,因此RPC重启后,它管理的所有服务都需要重新启动以重新向RPC注

1.2 生产应用场景

        NFS网络文件系统很像windows系统的网络共享、安全功能、网络驱动器映射,这也和linux系统里的Samba服务器类似。只不过一般情况下,windows网络共享服务或Samba服务用于办公局域网共享,而互联网中小型网站集群架构后端常用NFS进行数据共享,如果是大型网站,那可能会用到更复杂的分布式文件系统
        在企业集群架构的工作场景中,NFS作为所有前端web服务的共享存储,存储的内容一般包括网站用户上传的图片、附件、头像等,注意,网站的程序代码就不要放在NFS共享里了,因为网站程序是开发运维人员统一发布,不存在发布延迟问题,直接批量发布到web节点提供访问比共享到NFS里访问效率会更高些。
        NFS是当前互联网系统架构中常用的数据存储服务之一,中小型网站 (2000万pv(页面浏览量)以下)公示应用频率居高,大公司或门户除了使用NFS外,还可能会使用更为复杂的分布式文件系统

2.NFS工作原理

2.1 实例图

2.2 流程

首先服务器端启动RPC服务,并开启111端口

服务器端启动NFS服务,并向RPC注册端口信息

客户端启动RPC(portmap服务),向服务端的RPC(portmap)服务请求服务端的NFS端口

服务端的RPC(portmap)服务反馈NFS端口信息给客户端。 (服务器搭建成功后可以使用下列命令查看,一般都是2049)

3.NFS的使用

3.1.安装

[root@server ~]# cat /etc/services |grep -w nfs      # 查看当前NFS使用的端口
nfs             2049/tcp        nfsd shilp      # Network File System
nfs             2049/udp        nfsd shilp      # Network File System
nfs             2049/sctp       nfsd shilp      # Network File System
[root@server ~]# yum install nfs-utils -y                # 安装NFS

[root@server ~]# yum install rpcbind -y                 # 安装RPC(一般是默认已经安装)

3.2.配置文件

        主配置文件: /etc/exports,文件不一定存在
        /usr/sbin/exportfs:该文件是维护NFS共享目录资源的命令文件,可以使用命令重新共享/etc/exports的目录资源、卸载共享目录
        日志目录: /var/lib/nfs
        权限设置文件:
/var/lib/nfs/etab

3.3.主配置文件分析

         etc/exports文件默认为空文件,需要输入nfs共享命令

格式:          共享目录的路径        允许访问的NFS客户端 (共享权限参数)    

      共享权限参数  :(一般要写三大部分【权限     映射账户    传输模式:syns、async】) 

分析:                                                                        
        允许访问的NFS客户端: 可以写完整的IP地址或IP网段,如:
                192.168.48.130/24
                192.168.48.130/255.255.255.0
                192.168.48.0/24
                "*":允许所有主机都可以访问
权限参数:必须卸载园括号中,且括号是紧挨着主机名的,全选的相关参数如下,多个参数之间使用逗号隔开:

权限参数作用
ro只读
rw读写(最终还要看文件系统rwx权限)
root squash当NFS客户端以root账户访问时,映射为NFS服务器端的匿名账户(nobody)
no_root_squash当NFS客户端以root账户访问时,映射为root账户 (不推荐、不安全)
all_squash无论NFS客户端使用什么账户访问,均映射为NFS 服务器的匿名账户(nobody),推荐
no_all_squash客户端普通账户访问服务器的数据时,实际的信息原样显示
anonuid=将文件的用户和工作组映射为指定UID和GID,若不指定则默认为
anongid=65534 (nobody)
sync        同步,同时将数据写入内存与硬盘中,保证数据不会丢失,推荐
async异步,优先将数据保存到内存,然后在写入硬盘,效率高,但可能会数据丢

exportx文件内容实例:

/home/public *(rw,sync) :对所有机共享/home/public目录,可读可写,同步传输

/home/public 192.168.48.131/24(ro,all_squash,sync): 只对131主机开发共享/home/public ,只读权限,客户端映射为nobody账户,同步传输        

/home/public 192.168.48.0/24(rw , sync,all_squash, anonuid=2000, anongid=2000):对192.168.48.0网段中所有主机开放/home/public 目录,可读可写,同步传输,客户端映射为nobody,uid为2000,gid为2000       

3.4 实验

建立NFS服务器,使用客户端访问

服务端: 

第一步: 服务server端操作,完成准备工作

        root@server ~]# setenforce 0

        [root@server ~]# systemctl stop firewalld

        [root@server ~]# yum instal1 nfs-utils -y

第二步:客户端node1操作,完成准备工作

        root@server ~]# setenforce 0

        [root@server ~]# systemctl stop firewalld

        [root@server ~]# yum instal1 nfs-utils -y

第三步:服务端server操作,新建共享目录,并设置权限
[root@server ~]# echo  "www.openlab.com"  > /nfsfile/redme
[root@server ~]# cat /nfsfile/redme 

[root@server ~]# chmod -Rf 777 /nfsfile/

第四步:服务端server操作,修改nfs配置文件

[root@server ~]# vim /etc/exports

                /nfsfile192.168.48.131/24(rw,a11_squash,sync)

第五步:服务端server操作,先启动rpc服务,后启动nfs服务

[root@server ~]# systemctl start rpcbind                # 先启动RPC
[root@server ~]# systemctl start nfs-server            # 启动NFS

[root@server ~]# systemctl enable rpcbind         # 设置开机启动
[root@server ~]# systemctl enable nfs-server

# 注意:启动rpcbind服务时,若启动失败,可以先停止服务。在重新启动

        systemct1 stop rpcbind

        systemct start rpcbind

客户端:

第六步:客户端node1操作,通过命令查询共享数据并远程挂载使用

# 查询远程共享信息:showmount        -参数         服务器IP地址

# 参数:
        # -e: 显示NFS服务器的共享列表

        # -a: 显示本地挂载的文件资源列表

        # -V: 显示版本号

[root@node1 ~]# showmount -e 192.168.17.128          # 查询128的共享信息
        Export list for 192.168.17.128:
        /nfsfile 192.168.17.129/24

[root@node1 ~]# mkdir /nfs1
[root@node1 ~]# mount -t nfs 192.168.17.128:/nfsfile  /nfs1/       

       # 将192.168.17.128这台主机的/nfsfile账户目录,以nfs文件格式远程挂载到本地的/nfs1下

[root@node1 ~]# cat /nfs1/redme 

第七步:客户端node1操作,配置开机挂载,实现永久性挂载

[root@node1 ~]# vim /etc/fstab 

挂载目录                                挂载设备         文件系统         defaults         0        0

192.168.17.128:/nfsfile         /nfs1                   nfs                defaults          0        0

[root@node1 ~]# mount -a
[root@node1 ~]# reoot

检测:
        

这篇关于NSF服务器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/392429

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

速盾:直播 cdn 服务器带宽?

在当今数字化时代,直播已经成为了一种非常流行的娱乐和商业活动形式。为了确保直播的流畅性和高质量,直播平台通常会使用 CDN(Content Delivery Network,内容分发网络)服务器来分发直播流。而 CDN 服务器的带宽则是影响直播质量的一个重要因素。下面我们就来探讨一下速盾视角下的直播 CDN 服务器带宽问题。 一、直播对带宽的需求 高清视频流 直播通常需要传输高清视频

一种改进的red5集群方案的应用、基于Red5服务器集群负载均衡调度算法研究

转自: 一种改进的red5集群方案的应用: http://wenku.baidu.com/link?url=jYQ1wNwHVBqJ-5XCYq0PRligp6Y5q6BYXyISUsF56My8DP8dc9CZ4pZvpPz1abxJn8fojMrL0IyfmMHStpvkotqC1RWlRMGnzVL1X4IPOa_  基于Red5服务器集群负载均衡调度算法研究 http://ww

RTMP流媒体服务器 crtmpserver

http://www.oschina.net/p/crtmpserver crtmpserver又称rtmpd是Evostream Media Server(www.evostream.com)的社区版本采用GPLV3授权 其主要作用为一个高性能的RTMP流媒体服务器,可以实现直播与点播功能多终端支持功能,在特定情况下是FMS的良好替代品。 支持RTMP的一堆协议(RT

云原生之高性能web服务器学习(持续更新中)

高性能web服务器 1 Web服务器的基础介绍1.1 Web服务介绍1.1.1 Apache介绍1.1.2 Nginx-高性能的 Web 服务端 2 Nginx架构与安装2.1 Nginx概述2.1.1 Nginx 功能介绍2.1.2 基础特性2.1.3 Web 服务相关的功能 2.2 Nginx 架构和进程2.2.1 架构2.2.2 Ngnix进程结构 2.3 Nginx 模块介绍2.4

阿里云服务器ces

允许公网通过 HTTP、HTTPS 等服务访问实例 https://help.aliyun.com/document_detail/25475.html?spm=5176.2020520101.0.0.3ca96b0b3KGTPq#allowHttp

常见的服务器

常见的Web服务器 1、Tomcat:Tomcat和Java结合得最好,是Oracle官方推荐的JSP服务器。Tomcat是开源的Web服务器,经过长时间的发展,性能、稳定性等方面都非常优秀。 2、Jetty:另一个优秀的Web服务器。Jetty有个更大的优点是,Jetty可作为一个嵌入式服务器,即:如果在应用中加入Jetty的JAR文件,应用可在代码中对外提供Web服务。 3、Resin:

Exchange 服务器地址列表的配置方法与注意事项

Exchange Server 是微软推出的一款企业级邮件服务器软件,广泛应用于企业内部邮件系统的搭建与管理。配置 Exchange 服务器地址列表是其中一个关键环节。本文将详细介绍 Exchange 服务器地址列表的配置方法与注意事项,帮助系统管理员顺利完成这一任务。 内容目录 1. 引言 2. 准备工作 3. 配置地址列表 3.1 创建地址列表 3.2 使用 Exchange

本地如何快速启动静态服务器

本地快速启动静态服务器 有许多第三方库可以帮助你快速启动一个静态服务器,甚至无需编写代码。通过命令行运行这些库后,它们会自动启动一个服务器并打开指定端口,展示当前目录下的文件内容: 电脑得提前安装NodeJS 1、http-server http-server 是一个轻量级的命令行工具,允许你快速启动一个静态文件服务器。 安装 npm install -g http-server