一、什么是文件系统?

  文件系统是对一个存储设备上的数据和元数据进行组织的一种机制。文件系统是在一个磁盘(包括光盘、软盘、闪盘及其它存储设备)或分区上组织文件方式方法,常见文件系统如ext2、ext3、ext4、NTFS或fat、fat32等。文件系统格式组织存储文件或数据的方法,目的是易于查询和存取数据,如果磁盘上没有文件系统也就无法存储数据了,因此,磁盘分区后能够使用之前必须建立对应的文件系统才行(类似买了电脑不装系统就无法使用)。

  (1)文件系统是对一个存储设备上的数据和元数据进行组织的一种机制;

  (2)分区必须格式化,创建的文件系统才能存放数据,不同的分区只能有一种文件系统。

  (3)Linux下常见文件系统ext2、ext3、ext4、zfs、xfs、和Reiserfs

      Windows下常见文件系统NTFS、FAT31。

二、NFS网络文件共享服务:

1、NFS概述:

  NFS是第一个构建于IP协议之上的现代网络文件系统;

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

  NFS网络文件系统的使用很像是windows系统的网络共享、安全功能、网络驱动器映射,这也和Linux里的samba服务类似。

2、NFS应用场景:

  在企业集群架构的工作场景中,NFS网络文件系统一般被用来存储共享视频、图片、附件等静态资源文件,NFS是当前互联网系统架构中最常用的数据存储服务之一,特别是中小型网站公司应用频率很高。

3、NFS挂载原理:

  传统挂载:mount  源  目标

  NFS挂载:mount  远端的IP地址:/video  本地目录(/video)

    -- 访问本地的video就到了远端地址的video目录下,和在本机访问没什么区别。

4、搭建NFS服务

  

  hostname 新主机名;su

  实验环境:Centos6.5 两台机器,

           一台 nfsserver -- 192.168.3.137

         一台 nfsclient  -- 192.168.3.138

                NFS主要有两个软件包 -- nfs-utils(包括rpc.nfsd、rpc.mountd)、rpcbind(Centos6版本)

(1)安装 nfs-utils 包,服务端和客户端都需要安装。

yum groupinstall #查看软件包,软件包是中文修改字符集(LANG=en)。

yum groupinstall -y "NFS file server"  #安装NFS包,一定要加双引号。

 

(2)服务端(nfsserver)启动 rpc 服务

/etc/init.d/rpcbind  start      #启动 rpc 服务

  查看本地有没有共享,rpc 服务对外的端口是 111

-------------------------------------------------------------------------------------

反例:出现如下报错表示 rpc 服务没有启动:

----------------------------------------------------------------------------------------

(3)服务端启动 nfs 服务

/etc/init.d/nfs  start     #启动 nfs 服务

  再次查看本地 rpc 服务,出现很多端口。

(4)将 rpcbind 和 nfs 设置成开机自启动。

chkconfig rpcbind on
chkconfig nfs on
chkconfig --list rpcbind  #检查状态
chkconfig --list nfs

  检查状态:

(5)客户端(nfsclent) 开启 rpcbind 服务,不用开启 nfs 服务

/etc/init.d/rpcbind  start    #开启 rpcbind 服务

chkconfig rpcbind on        #设置 rpcbind 服务开机自启动
chkconfig --list rpcbind

(6)/etc/exports -- nfs 的配置文件,此文件默认为空

vim /etc/exports    #编辑文件

sync 同步到磁盘,把数据从buffer写入到磁盘
async -- 表示写入到缓存里
ro -- read only -- 表示只读
rw -- 可读可写

(7)重启 nfs 服务,不能用 restart 重启,要用 reload 重启。

/etc/init.d/nfs  reload   #平滑重启 nfs 服务

  在本机做检查,查看共享的文件是否能共享。

showmount  -e  localhost

  在客户端(nfsclient)查看是否能发现共享文件。

showmount  -e  192.168.3.137   #访问的IP地址

----------------------------------------------------------------------------------------------------------

注意:如果出现客户端无法发现服务端的共享文件,需要从以下方面排错。

①检查是否关闭防火墙:

  

service  iptables stop

②能否 ping 通对端地址

③能否 telnet 远程登录对端。后面接 rpc 的端口号 111(下述为 telnet 登录对端)

  

  一般(2)(3)没问题是可以正常访问的,注意要关闭防火墙。

-----------------------------------------------------------------------------------------------------------

(8)在客户端(nfsserver)挂载。

mount  -t nfs 192.168.3.137:/data  /mnt     #将对端共享的目录挂载到本地的 /mnt 目录下

(9)在客户端的 /mnt 目录下查看文件是否成功共享。

服务端(nfsserver)的 /data 目录:

  

客户端(nfsclient)查看 /mnt 目录:

  

  文件已经共享。

(10)测试:服务端删除一个文件,客户端查看共享文件内容。

服务端:删除 abc.txt 文件

  

客户端:查看共享文件

  

但是:在服务端配置共享文件的时候,给的权限是可读可写,此时却不能写。

  

因为这是目录本身的权限问题:

  

服务端的 /data 目录对于其他用户没有可写的权限,因此加上权限即可。

chmod  /data

客户端可写。

(11)其他授予写权限的操作。

客户端进行写的操作,用户和用户组属于 nfsnobody

  

在 /var/lib/nfs/etab 文件中说明 nfs其他用户的 UID 是从 65534 开始。

  

nfsnobody的UID和GID都为65534

   

由于NFS其他用户都是属于 nfsnobody,所以可以将服务端的 /data  目录所属组和所属主修改为 nfsnobody。

  

/data 目录其他用户不具备写的权限,但是将 /data 的所属组和所属主更改为 nfsnobody;

在客户端进行增删操作。

  

客户端可以直接进行创建文件,同时最后删除所有文件,在服务端查看是否文件全部删除。

  

NFS网络文件共享服务搭建完成。

  但是挂载在 /mnt 目录下,开机会丢失,所以最好把共享的目录放在 rc.local 里或者 fstab 中。

  

NFS文件系统及搭建NFS共享服务的更多相关文章

  1. umount nfs文件系统 显示 umount.nfs: device is busy

    网上的方法一般都是 fuser -m  /nfs 查出进程号,然后杀死进程号,或者fuser -km /nfs直接杀死,我试了下都不行 解决方法: 对于nfs文件系统来说,umount -l /nfs ...

  2. NFS 文件系统的搭建

    教程: 一.配置linux内核: 进入打过at91补丁的linux2.6内核源代码树的根目录 make menuconfig进入内核配置程序. 1.  Networking ---> Netwo ...

  3. NFS文件系统存储服务部署

    1 NFS介绍 1.1 什么是NFS? NFS是Network File System的缩写,中文名称是网络文件系统.它的主要功能是通过网络让不用的主机系统之间可以共享文件或者目录.NFS客户端通过挂 ...

  4. 网络共享服务(二)之NFS

    NFS: Network File System,是一种基于TCP/IP传输的网络文件系统协议,最初由SUN公司开发.通过使用NFS协议,客户机可以像访问本地目录一样访问服务器中的共享资源.但是,NF ...

  5. 基于OneMap的水利行业共享服务平台搭建步骤

    今天上午再次学习Esri技术培训中心的“GIS服务共享与运维管理——之OneMap解决方案”课程,从中学习了OneMap的产品架构以及基于OneMap共享服务平台的搭建步骤.下面把其中水利行业的共享服 ...

  6. NFS(网络文件系统的搭建)

    关于NFS的原理,我在这就不概诉了,其实非常简答的理解就是一个网络磁盘,你需要把它挂载到你的磁盘上使用而已.那接下来谈谈如和搭建NFS网络文件系统. 需要使用2台机器作此实验,我分别配置IP为192. ...

  7. Linux搭建NFS服务

    一.NFS服务简单介绍 NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中, ...

  8. 4、架构--NFS实践、搭建web服务、文件共享

    笔记 1.晨考 1.数据备份的方式有哪些 全量和增量 2.数据备份的命令有哪些,都有哪些优点缺点 cp : 本地,全量复制 scp :远程,全量复制 rsync :远程,增量复制 3.rsync的参数 ...

  9. 搭建 NFS 服务 & 实时同步

    今日内容 NFS简介 实现 NFS 文件同步功能 NFS 配置详解 统一用户 搭建 web 服务 NFS 实现文件共享 内容详细 1.NFS 简介 1.1 介绍 实现多台 web 服务器可以共享数据资 ...

随机推荐

  1. 从项目中理解SSM框架

    我们看招聘信息的时候,经常会看到这一点,需要具备SSH框架的技能:而且在大部分教学课堂中,也会把SSH作为最核心的教学内容. 但是,我们在实际应用中发现,SpringMVC可以完全替代Struts,配 ...

  2. Wonder第一期3D引擎和编辑器线下培训班报名开始啦(免费学习)

    Wonder第一次举办 针对3D底层技术的 线下培训班,免费学习,请大家多多支持-感谢- 培训地点 成都 开课时间 报名满5人开课. 报名方式 加QQ群:732861508 备注请写:报名培训 老师介 ...

  3. 微信小程序APP生命周期

    小程序APP生命周期需要先从app.js这个文件开始,App() 必须在 app.js 中调用,必须调用且只能调用一次,app.js中定义了一些应用的生命周期函数 onLaunch----当小程序初始 ...

  4. css3 伪类实现右箭头→

    css3 实现右箭头→ <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...

  5. Windows密码获取和破解(初探)

    Windows密码获取和破解 本文只是简单的讲明密码获取和破解 具体的操作细节均以模糊或具体代码混淆等方式避开 如有兴趣请自行研究,本文不做细说~~~ 获取思路: Windows密码一般是以" ...

  6. SpringMVC使用Redis共享session

    在使用之前,请确认项目已经整合了Redis 一.加入依赖 <dependency> <groupId>org.springframework.session</group ...

  7. mysql数据库排坑过程

    刚安装mysql后想通过navicat来连接mysql,发现报错 1251这个错误,不慌.这个很简单. 首先通过cmd进入mysql. 然后修改密码规则 ALTER USER 'root'@'loca ...

  8. Seafile对接Amazon S3存储后端

    安装python第三方库boto easy_install boto 进入seafile配置文件.conf添加下面内容 [commit_object_backend] name = s3 bucket ...

  9. docker拉取慢(net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting head)

    systemctl restart docker在docker-hub拉取慢,因为服务器在外网 直接配置阿里云镜像就可以 首先: vim /etc/docker/daemon.json加入下面的那句 ...

  10. ubuntu 18.04 安装并配置adb

    获取最新的adb包 wget https://dl.google.com/android/repository/platform-tools-latest-linux.zip 将软件包解压到指定位置 ...