1.什么是NFS?

Network file system  网络文件系统   nfs共享存储

2.nfs能干什么?

nfs 能为 不同主机系统之间    实现    文件的共享

3.为什么要使用nfs?

在集群架构中使用

4.nfs能解决什么问题?

1.解决多台机器静态资源一致性问题
2.解决多态机器资源共享
3.解决磁盘空间浪费的问题

5.使用nfs的注意事项?

1.添加共享存储,只会带来网站的访问延时和消耗,并不会增加网站访问的速度.
2.CDN---->(了解即可) 1.购买厂商CDN ---> 用户请求img--->CDN--->负载均衡-->Web-->存储-->CDN缓存该图片
2.所有的web都是用共享存储,图片此时一致, 只需要将图片定期的推送至CDN

6.nfs实现的原理解析?

本地文件操作方式:
1.当用户执行mkdir命令,BashShell无法完成该命令操作,会将其翻译给内核。
2.Kernel内核解析完成后会驱动对应的磁盘设备,完成创建目录的操作。

NFS实现原理

1.NFS客户端执行增、删等操作,客户端会使用不同的函数对该操作进行封装。(windows linux mac)
2.NFS客户端会通过TCP/IP的方式传递给NFS服务端。(可靠)
3.NFS服务端接收到请求后,会先调用portmap进程进行端口映射。
4.nfsd进程用于判断NFS客户端是否拥有权限连接NFS服务端。
5.Rpc.mount进程判断客户端是否有对应的权限进行验证。读 写
6.idmap进程实现用户映射和压缩。
7.最后NFS服务端会将客户端的函数转换为本地能执行的命令,然后将命令传递至内核,由内核驱动硬件。 注意: rpc是一个远程过程调用,那么使用nfs必须有rpcbind服务

7.安装、配置、nfs服务

1.安装
[root@nfs ~]# yum install nfs-utils -y 2.配置
1.共享什么目录?
2.共享给谁使用?
3.共享后目录,客户端拥有什么权限?
[root@nfs ~]# cat /etc/exports
/data 172.16.1.0/24(rw) 3.根据配置进行初始化环境
[root@nfs ~]# mkdir /data
[root@nfs ~]# chown -R nfsnobody.nfsnobody /data/ 4.启动
[root@nfs ~]# systemctl enable nfs
[root@nfs ~]# systemctl start nfs 5.客户端测试
[root@backup ~]# yum install nfs-utils -y
[root@backup ~]# showmount -e 172.16.1.31
Export list for 172.16.1.31:
/data 172.16.1.0/24 挂载远程172.16.1.31的/data至本地的/mnt目录
[root@backup ~]# mount -t nfs 172.16.1.31:/data /mnt 6.错误的示范
#访问被拒绝 (没有允许该网段访问)
[root@backup ~]# mount -t nfs 10.0.0.31:/data /media/
mount.nfs: access denied by server while mounting 10.0.0.31:/data #能够连接,但是权限被拒绝
[root@backup mnt]# touch file
touch: cannot touch ‘file’: Permission denied 7.多个客户端共享一个存储服务器 (NFS)
8.实现开机自动挂载(因为服务器不重启) 扩展了解即可
[root@web01 ~]# cat /etc/fstab
172.16.1.31:/data /media nfs defaults 0 0 PS: 如果nfs服务端出现问题: 客户端重启则会无法启动成功
1.等待1分38s 自动进入系统
2.进入单用户模式,注释开机自启动nfs
3.将nfs恢复正常

9.nfs相关的配置参数

nfs共享参数 参数作用

rw* 读写权限 (最多)

ro 只读权限 (只希望看,不希望写)

root_squash 当NFS客户端以root管理员访问时,映射为NFS服务器的匿名用户nfsnobody(不常用)

no_root_squash 当NFS客户端以root管理员访问时,映射为NFS服务器的root管理员(不常用)

no_all_squash 无论NFS客户端使用什么账户访问,都不进行用户压缩 ( 后面讲云计算课程会用上 )

all_squash 无论NFS客户端使用什么账户访问,均映射为NFS服务器的匿名用户(常用)

sync* 同时将数据写入到内存与硬盘中,保证不丢失数据

async 优先将数据保存到内存,然后再写入硬盘;这样效率更高,但可能会丢失数据

anonuid* 配置all_squash使用,指定NFS的用户UID,必须存在系统

anongid* 配置all_squash使用,指定NFS的用户UID,必须存在系统

1.rw 和 ro
[root@nfs ~]# cat /etc/exports
/data 172.16.1.0/24(ro)
[root@nfs ~]# systemctl restart nfs #提示,该目录是一个只读文件
[root@web01 media]# touch file
touch: cannot touch ‘file’: Read-only file system 2.验证all_squash anonuid anongid
[root@nfs ~]# cat /etc/exports
/data 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)
1.创建系统真实用户,指定uid和gid为666
[root@nfs ~]# groupadd -g 666 www
[root@nfs ~]# useradd -u666 -g666 www
[root@nfs ~]# id www
uid=666(www) gid=666(www) groups=666(www) 2.变更属主和属组
[root@nfs ~]# chown -R www.www /data/ 3.重启nfs
[root@nfs ~]# systemctl restart nfs 4.客户端使用(一定要与服务端使用的匿名用户一致)
[root@web01 ~]# groupadd -g 666 www
[root@web01 ~]# useradd -u666 -g666 www
[root@web01 ~]# mount -t nfs 172.16.1.31:/data/ /media/ 10.nfs如何共享多个目录?
[root@nfs ~]# cat /etc/exports
/data 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)
/data_2 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)

1.NFS存储优点

1. NFS简单易用、方便部署、数据可靠、服务稳定、满足中小企业需求

2. NFS的数据都在文件系统之上,所有数据都是能看得见。

除了NFS: ( Glusterfs分布式 赠送 ) MooseFS FastDFS

2.NFS存储局限

1. 存在单点故障, 本身NFS不支持高可用,也不支持集群.

2. NFS数据都是明文,并不对数据做任何校验,也没有密码验证(强烈建议内网使用)。

3.NFS应用建议

1. 生产场景应将静态数据(jpg\png\mp4\avi\css\js)尽可能放置CDN场景进行环境, 以此来减少后端存储压力

2. 如果没有缓存或架构、代码等,本身历史遗留问题太大,在多存储也没意义

PS:  NFS就是用来共享  其他什么都没有.     所有的静态都是CDN提供访问的

NFS实战:

环境准备:
服务器系统 角色 IP
CentOS 7.6 NfsServer(A) 172.16.1.31
CentOS 7.6 NfsClient(B) 172.16.1.41
CentOS 7.6 NfsClient(C) 172.16.1.7 准备3台虚拟机服务器,并且请按照要求搭建配置NFS服务。
NFS服务端(A)
NFS客户端(B)
NFS客户端(C)
1.在NFS服务端(A)上共享/data/w(可写) 及/data/r(只读)
2.在NFS客户端(B/C)上进行挂载

服务端A:

1. 安装nfs-utils
[root@nfs ~]# yum install nfs-utils -y 2. 配置nfs
[root@nfs ~]# cat /etc/exports
/data/r 172.16.1.0/24(ro,sync,all_squash,anonuid=666,anongid=666)
/data/w 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666) 3. 根据配置进行初始化环境(创建对应的用户及共享目录)
[root@nfs ~]# groupadd -g 666 www
[root@nfs ~]# useradd -u666 -g666 www
[root@nfs ~]# mkdir /data/{r,w} -p
[root@nfs ~]# chown -R www.www /data/ 4.重启nfs服务
[root@nfs ~]# systemctl restart nfs

客户端B:

1.安装nfs-utils
[root@web01 ~]# yum install nfs-utils -y
[root@web01 ~]# systemctl status rpcbind //检查bind服务有没有开启 2.创建本地挂载点和所需用户
[root@web01 ~]# mkdir -p /data/{r,w}
[root@web01 ~]# groupadd -g 666 www
[root@web01 ~]# useradd -u666 -g666 www 3.查看远程服务器共享的目录
[root@web01 ~]# showmount -e 172.16.1.31
Export list for 172.16.1.31:
/data/r 172.16.1.0/24
/data/w 172.16.1.0/24 4. 挂载
[root@web01 ~]# mount -t nfs 172.16.1.31:/data/r /data/r/
[root@web01 ~]# mount -t nfs 172.16.1.31:/data/w /data/w/
[root@web01 ~]# df -h
172.16.1.31:/data/r 40G 2.0G 39G 5% /data/r
172.16.1.31:/data/w 40G 2.0G 39G 5% /data/w

客户端C:

 1-3和客户端B操作步骤一致
4.挂载
[root@backup ~]# mount.nfs 172.16.1.31:/data/r /mnt/
[root@backup ~]# mount.nfs 172.16.1.31:/data/w /media/

总结:

1.什么是NFS?
网络文件系统
2.NFS主要实现的功能?
让不同主机之间能共享目录
https://blog.csdn.net/wykkunkun/article/details/79638288
3.NFS到底有什么用?
日常 没用
网站架构 有用?
没有共享前有什么问题?
共享后解决了什么问题?
1.一致性
2.减少磁盘空间
4.NFS实现共享原理?
5.NFS 安装 配置 使用?
6.客户端挂载?
showmount
mount
df -h
/etc/fstab
6.多个客户端如何进行NFS的挂载?
测试多个客户端数据是否一致
7.NFS相关参数?
rw
all_squash
anonuid
anongid
sync
8.NFS服务端如何共享多个目录
9.NFS使用建议 CDN -->CNAME

4. NFS存储服务器搭建的更多相关文章

  1. 2 NFS高可用解决方案之NFS的搭建

    preface 我们紧接着上一篇博文的基础(drbd+heartbeat的正常工作,http://www.cnblogs.com/liaojiafa/p/6129499.html)来搭建NFS的服务. ...

  2. Linux之我有你也有-共享平台NFS服务器搭建

    Linux之我有你也有-共享平台NFS服务器搭建 最近因工作需要,所以要搭一个共享的服务器用于存储.实现你有我有大家有的共享的和谐局面.想到了NFS-Network File System.接下来我便 ...

  3. NFS的搭建(sudo apt-get install nfs-kernel-server),TFTP服务器(sudo apt-get install tftpd-hpa tftp-hpa)

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/Osean_li/article/details/53240705 ***************** ...

  4. NFS实现(双httpd + php-fpm + nfs + mysql 搭建discuz论坛)的方法

    NFS相关介绍 一.NFS简介 1. NFS(Network File System):NFS是一个文件共享协议, 也是是在类Unix系统中在内核中实现的文件系统. 2. 起源:最早是由SUN公司研发 ...

  5. NFS服务器搭建-共享PC与ARM主板文件

    NFS服务器搭建-共享PC与ARM主板文件 在搭建好交叉编译环境之后需要实现目标板与宿主机的文件共享,在这里选择NFS,由于资料较多.需要注意的以下几点: 目标板与宿主机需要连接在同一个网段内. 宿主 ...

  6. nfs存储服务器

    1.nfs的基础简介 1.1:什么是nfs? 它的主要功能是通过网络让不同的机器系统之间可以彼此共享文件和目录.NFS服务器可以允许NFS客户端将远端NFS服务器端的共享目录挂载到本地的NFS客户端中 ...

  7. Ubuntu环境下NFS服务器搭建

    看到鸟哥私房菜对NFS的介绍,就想试试玩一下.看起来步骤也很简单. 1.背景名词. NFS(Network File System) 作用:让所有的Unix-like 机器通过网络共享彼此的文件 局限 ...

  8. nfs环境搭建报错clnt_create: RPC: Program not registered

    有时候搭建完成后,使用showmount -e ip检测服务端服务器情况的是,会出现clnt_create: RPC: Program not registered 这个错误,表示rpc程序为注册成功 ...

  9. Linux下网络文件系统NFS服务搭建易错点总结

    一.环境准备: 1 [root@czh ~]# cat /etc/redhat-release 2 CentOS release 6.7 (Final) 3 [root@czh ~]# uname - ...

随机推荐

  1. DefaultSerializer requires a Serializable payload but received an object of type [model.Admin]

    一.问题描述:   在用redis做二级缓存时,出现如下异常   DefaultSerializer requires a Serializable payload but received an o ...

  2. 规模、性能、弹性全面升级,让天下没有难用的 K8s

    作者 | 汤志敏 阿里云容器服务开发负责人 Kubernetes 是云原生时代的基础设施.云上的分布式操作系统. 9 月 26 日云栖大会容器专场,在<拐点已至,云原生引领数字化转型升级> ...

  3. event.stopPropagation()、event.preventDefault()与return false的区别

    做小demo时经常用到return false来取消默认事件,但一直不是很懂它和preventDefault()等的区别,今天查了查文档和大神们的博客,在这里对相关知识点做一个总结 首先开门见山,总结 ...

  4. django查询表记录的十三种方法

    django查询表记录的十三种方法 all() 结果为queryset类型 >>> models.Book.objects.all() <QuerySet [<Book: ...

  5. Spring Boot(三) 使用Lombok

        C#写的多了用习惯了众多的语法糖,再写起来Java总会有一些非常不舒服的地方.比如用惯了C#的属性在用起来Java的属性,写起来就会感觉不够优雅.如:定义一个Person类 public cl ...

  6. Java8新特性——接口默认方法

    Java 8 新增了接口的默认方法. 简单说,默认方法就是接口可以有实现方法,而且不需要实现类去实现其方法. 我们只需在方法名前面加个default关键字即可实现默认方法. 为什么要有这个特性? 首先 ...

  7. [Mathematics][MIT 18.03] Proof of a Theory about the Solution to Second-order Linear Homogeneous Differential Equation

    At first, I'd like to say thank you to MIT open courses which give me the privilege to enjoy the mos ...

  8. .Net Core 商城微服务项目系列(十四):分布式部署携程Apollo构建配置中心

    一.开场白 在系统设计里我们有很多配置希望独立于系统之外,而又能够被系统实时读取.但是在传统的系统设计里,配置信息通常是耦合在系统内的,比如.net里通常会放在App.config或者web.conf ...

  9. mybatis - 通用mapper

    title: 玩转spring-boot-mybatis date: 2019-03-11 19:36:57 type: "mybatis" categories: mybatis ...

  10. linux下搭建nginx+mysql+apache

    对于开发人员来说,进行Web开发时可以用Apache进行网站测试,然而当一个Web程序进行发布时,Apache中并发性能差就显得很突出,这时配置一台Nginx服务器显得尤为重要. 以下是配置Nginx ...