NFS服务器简介

NFS的使用

权限参数

简易实验配置一:

要求:客户端借用nfs服务器可以同步服务端的文件

步骤:服务端配置(/var/lib/nfs日志存放目录)

创建文件:(主配置文件有可能存在,也有可能不存在,不存在需要创建文件)

检验的文件

开启服务(注意先后顺序)

查看本传动机的挂载(检查)

客户端配置

安装nfs软件与开启服务( systemctl restart nfs-utils.service )

创建挂载文件夹

挂载

检验客户端是否可以查看服务端共享的文件(成功)

户端使用autofs自动挂载

简易实验配置二

步骤

结果 对比

启动autofs产生的信息

检查是否可以触发自动挂载

自动解挂载方法

退出这个目录,等待10秒

查看检验

实验完成


NFS服务器简介

NFS是Network File System的缩写,中文称为网络文件系统,它的主要功能是通过网络(一个局域网)让不同的主机系统之间可以共享文件或目录,NFS的客户端(一般为应用服务器,例如web)可以通过挂载(mount)的方式将NFS服务器共享的数据目录挂载到NFS客户端本地系统中(就是某一个关在点下),从客户端本地看,NFS服务器端共享目录就好像是客户端自己的磁盘分区或者目录一样,而实际上却是远端的NFS服务器的目录。

NFS企业在企业中的应用场景,在企业集群架构的工作场景中,NFS网络文件系统一般被用来存储共享视频、图片、附件等静态资源文件,通常网站用户上传的文件都会放到NFS共享中,例如BBS产品的图片、附件、头像(网站BBS的程序不要放在NFS共享中),然后前端所有节点在访问这些静态资源时都会读取NFS存储上的资源。

NFS是当前互联网系统架构中最常用的数据存储服务之一,特别是中小型网站应用频率更高。

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

NFS服务器可以让PC将网络中的NFS服务器共享的目录挂载到本地端的文件系统中,而在本地端的系统中看来,那个远程主机的目录就好像是自己的一个磁盘分区一样。

由于NFS支持的功能比较多,而不同的功能都会使用不同的程序来启动,每启动一个功能就会启用一些端口来传输数据,因此NFS的功能所对应的端口并不固定,而是随机取用一些未被使用的小于1024的端口用于传输。但如此一来就会产生客户端连接服务器的问题,因为客户端需要知道服务器端的相关端口才能够连接。

此时就需要RPC(Remote Procedure Call,远程过程调用)的服务。由于当服务器在启动NFS时会随机选取数个端口号,并主动向RPC注册,所以RPC知道每个NFS功能所对应的端口号,RPC将端口号通知给客户端,让客户端可以连接到正确的端口上去。RPC采用固定端口号port 111来监听客户端的需求并向客户端响应正确的端口号。

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

exportfs的选项
-a全部挂载或卸载/etc/exports中的内容
-r重新读取/etc/exports中的信息,并同步更新/etc/exports,/var/lib/nfs/xtab
-u卸载单一目录(和-a一起使用为卸载所有/etc/exports文件中的目录)
-v在export的时候,将详细的信息输出到屏幕上

NFS的使用

RPC主程序:rpcbind

NFS主程序:nfs-utils

[root@localhost ~]# yum install rpcbind

[root@localhost ~]# yum install nfs-utils

/etc/exports主配置文件(文件不一定存在)

/usr/sbin/exportfs 维护NFS共享资源的命令,可以使用该命令重新共享/etc/exports更新的目录资源、将NFS server共享的目录卸载或重新共享等

/var/lib/nfs/*tab

在NFS服务器中,日志文件都放置到/var/lib/nfs目录中,在该目录下有两个比较重要的日志文件,一个是etab,主要记录了NFS所共享出来的目录的完整权限设置值;另一个是xtab,记录了曾经链接到此NFS服务器的相关客户端数据。

/usr/sbin/showmount 该命令主要用在client端。这个命令可以查看NFS共享出来的目录资源

/etc/exports配置文件的语法与参数

| 共享目录 | 主机名(权限) |
| -------- | -------------- |

该文件内,每一行最前面表示要共享的目录。

主机名的设置方式:

可以使用完整的IP或者是网络号,例如172.24.8.128或172.24.8.0/24或者172.24.8.128/255.255.255.0

可以使用主机名,但是主机名必须要在/etc/hosts内,或者可以使用DNS域名解析解析出对应的IP地址。可以用“*”代表所有主机。

权限参数

 权限需要写在括号内,且括号是紧接着主机名的。权限相关参数可以写多个,多个参数之间用逗号隔开,具体相关参数说明如下:

参数值

说明

rw/ro

该目录共享的权限是可读写还是只读,但最终能否读写,还是与文件系统的rwx有关

sync/async

sync代表数据会同步写入到内存与硬盘中,async则代表数据会先暂存于内存当中,而非直接写入硬盘

no_root_squash/root_squash

若客户端在共享目录里创建的文件的所属者和所属组是root用户和root组,那么显示文件的属主和属组时有以下两种情况:norootsquash表示,文件的所属者和所属组是root用户和root组;root_squash表示将root用户和组映射为匿名用户和组(默认设置)。

all_squash/no_all_squash

allsquash:客户端所有用户创建文件时,客户端会将文件的用户和组映射为匿名用户和组noall_squash:客户端普通用户创建的文件的UID和GID是多少,服务端就显示为多少(默认设置)

anonuid=anongid=

将文件的用户和组映射为指定的UID和GID,若不指定默认为65534(nfsnobody)

简易实验配置一:

要求:客户端借用nfs服务器可以同步服务端的文件

步骤:服务端配置(/var/lib/nfs日志存放目录)

创建文件:(主配置文件有可能存在,也有可能不存在,不存在需要创建文件)

vim /etc/exports //编写主配置文件
mkdir /nfsdata //创建目录
/nfsdata  192.168.5.0/24(rw,no_root_squash)//主文件配置内容

检验的文件

开启服务(注意先后顺序)

systemctl restart rpcbind //开启rpc服务
systemctl restart nfs-server.service //开启nfc服务

查看本传动机的挂载(检查)

showmount -e 192.168.5.128

客户端配置

安装nfs软件与开启服务( systemctl restart nfs-utils.service )

创建挂载文件夹

mkdir /mountdata

挂载

mount 192.168.5.128:/nfsdata  /mountdata/

检验客户端是否可以查看服务端共享的文件(成功)

mount命令查看挂载信息

户端使用autofs自动挂载

在一般NFS文件系统的使用过程中,如果客户端要使用服务端所提供的文件系统,可以在/etc/rc.d/rc.local中设置开机时自动挂载(/etc/rc.d/rc.local文件中写入的命令,在每次启动系统用户登录之前都会执行一次);也可以在登录系统后手动利用mount来挂载。

由于网络的问题,NFS服务器与客户端的连接不会一直存在,当我们挂载了NFS服务器之后,任何一方脱机都可能造成另外一方等待超时。为了解决这样的问题,就出现了下面的想法:

1、当客户端在有使用NFS文件系统的需求时才让系统自动挂载。

2、当NFS文件系统使用完毕后,让NFS自动卸载。

于是就产生了autofs这个服务。

autofs这个服务是在客户端的上面,它会持续的检测某个指定的目录,并预先设置当使用到该目录的某个子目录时,将会取得来自服务器端的NFS文件系统资源,并进行自动挂载的操作。

简易实验配置二

让客户端实现自动挂载操作

步骤

vim /etc/auto.master(修改主配置文件)挂载的父目录(autofs会帮你自动创建)      挂载信息存储路径/nfsclient                                  /etc/auto.nfs
vim  /etc/auto.nfs

 重启服务

systemctl restart autofs

结果 对比

启动autofs产生的信息

检查是否可以触发自动挂载

自动解挂载方法

退出这个目录,等待10秒

查看检验

实验完成

十分钟学习nfs服务器相关推荐

  1. 十分钟学习自然语言处理概述

    十分钟学习自然语言处理概述 摘要:近来自然语言处理行业发展朝气蓬勃,市场应用广泛.笔者学习以来写了不少文章,文章深度层次不一,今天因为某种需要,将文章全部看了一遍做个整理,也可以称之为概述.关于这些问 ...

  2. 十分钟用Windows服务器简单搭建DHCP中继代理!!

                         十分钟用Windows服务器简单搭建DHCP中继代理!! 一.什么是中继代理? 大家都知道DHCP分配地址都需要用到IP广播,但是广播是不能在两个网段之间进行 ...

  3. vue-cli十分钟学习入门笔记――开袋即食

    vue-cli十分钟学习之从一无所知到糊里糊涂 文章目录 vue-cli十分钟学习之从一无所知到糊里糊涂 1.为啥要学习Vue? 2.NodeJs安装及其npm介绍 3.脚手架vue-cli安装 4. ...

  4. 十分钟万台服务器部署能力,探秘阿里双十一弹性扩容背后的技术故事

    往往在大促等高峰时段都需要对流量提前预估,但实际上预先计算好的资源和应用容量,依然可能不足以支撑流量高峰,需要紧急扩容:而容器技术则非常适合这种场景,在需要时快速地.自动弹性伸缩.那么在业务需求极速上 ...

  5. 十分钟学习nginx

    启动 nginx 重启 nginx -s reopen 停止 nginx -s stop 热加载 ./nginx -s reload 测试修改配置文件是否正常 nginx -t 默认配置文件位置 /u ...

  6. pandas 按字符串肚脐眼 读取数据_十分钟学习pandas! pandas常用操作总结!

    学习Python, 当然少不了pandas,pandas是python数据科学中的必备工具,熟练使用pandas是从sql boy/girl 跨越到一名优秀的数据分析师傅的必备技能. 这篇pandas ...

  7. 十分钟学习python_Python学习笔记一:十分钟入门

    [转]为什么要自己敲呢?--学习的过程. 简介: Python是一种动态解释型的编程语言.Python可以再Windows,UNIX,MAC等多种ca 特点: 1. python使用C语言开发,但是p ...

  8. 十分钟学习python_10分钟带你入门Cython

    1. Cython是什么? Cython是一个编程语言,它通过类似Python的语法来编写C扩展并可以被Python调用.既具备了Python快速开发的特点,又可以让代码运行起来像C一样快,同时还可以 ...

  9. 每天学习十分钟1之心路历程

    1.工作到现在也有半年多了,很少静下心来思考思考想点东西,中午休息时间看了"职业发展"的一点视频,颇有感触,很认同其中的几个观点: ①.平时求生存,周末求发展.这个也不需要什么解释 ...

最新文章

  1. vue后台增删改查_Vue 原生实现商城购物车增删改查
  2. Java8中的HashMap分析
  3. SAP中smartforms参数
  4. Leetcode-260. 只出现一次的数字 III
  5. python一年收入_你的年收入过5万了吗?数据科学家的Python模块和包
  6. ubuntu中vscode配置python_ubuntu下vs code的python虚拟环境的配置
  7. 产品研发过程管理专题——软件工程(软件目的需求开发与管理)
  8. Android 实现计时器
  9. 来教你用什么泡脚好,泡脚的好处有那些?
  10. Android开发之SDCardUtils工具类。java工具详细代码,附源代码。判断SD卡是否挂载等功能...
  11. 【BZOJ 3669】 [Noi2014]魔法森林 LCT维护动态最小生成树
  12. 汉字转语音 android 软件,文字转语音助手
  13. 在安卓手机中使用微信保存图片提示失败的处理
  14. Web3即将到来,我们做了什么?
  15. html图片点击左右滑动效果,基于jquery实现点击左右按钮图片横向滚动
  16. html5-canvas常用的api介绍
  17. C++ 计算多边形的面积,计算IOU
  18. Excel操作:如何锁定单元格、有几种方法实现分类汇总
  19. 开关电源设计时如何减小地弹
  20. 让微信二维码扫描你的APK

热门文章

  1. Python字典视图浅析
  2. 【Steam VR 2.0】3. Skeleton Poser 自定义抓取手势的使用
  3. 国内外主流容灾备份厂商介绍
  4. 长安链源码学习v2.2.1--ioc机制(十)
  5. Duet 2 WIFI 主板略
  6. onMouse 鼠标移入移出事件
  7. widget jquery 理解
  8. C++循环结构实例:估算e值:计算e=1+(1/1!)+(1/2!)+…的近似值,1/n!小于10^(-7)时停止计算
  9. Cobalt Strike(三)DNS beacon 的使用与原理
  10. opencv简易数字识别