一. 什么是FastDFS

1.介绍FastDFS

FastDFS是用c语言编写的一款开源的分布式文件系统,它是由淘宝资深架构师余庆编写并开源。FastDFS专为互联网量身定制,充分考虑了冗余备份负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用FastDFS很 容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务

2.为什么要使用FastDFS

上边介绍的NFS、GFS都是通用的分布式文件系统,通用的分布式文件系统的优点的是开发体验好,但是系统复杂 性高、性能一般,而专用的分布式文件系统虽然开发体验性差,但是系统复杂性低并且性能高。fastDFS非常适合 存储图片等那些小文件,fastDFS不对文件进行分块,所以它就没有分块合并的开销,fastDFS网络通信采用 socket,通信速度很快

二.FastDSF架构

架构说明 :

FastDFS架构包括 Tracker server(跟踪服务器)和Storageserve(存储服务器)r。客户端请求Tracker server进行文件上传、下载,通过Tracker server调度最终由Storage server完成文件上传和下载

此图需要加深理解:

1.Tracker

Tracker Server作用是负载均衡和调度,通过Tracker server在文件上传时可以根据一些策略找到Storage server提 供文件上传服务。可以将tracker称为追踪服务器或调度服务器。
FastDFS集群中的Tracker server可以有多台,Tracker server之间是相互平等关系同时提供服务,Tracker server 不存在单点故障。客户端请求Tracker server采用轮询方式,如果请求的tracker无法提供服务则换另一个tracker

2.Storage

Storage Server作用是文件存储,客户端上传的文件最终存储在Storage服务器上,Storage server没有实现自己的 文件系统而是使用操作系统的文件系统来管理文件。可以将storage称为存储服务器。
Storage集群采用了分组存储方式。storage集群由一个或多个组构成,集群存储总容量为集群中所有组的存储容量 之和。一个组由一台或多台存储服务器组成,组内的Storage server之间是平等关系,不同组的Storage server之 间不会相互通信,同组内的Storage server之间会相互连接进行文件同步,从而保证同组内每个storage上的文件完 全一致的。一个组的存储容量为该组内存储服务器容量最小的那个,由此可见组内存储服务器的软硬件配置最好是 一致的。
采用分组存储方式的好处是灵活、可控性较强。比如上传文件时,可以由客户端直接指定上传到的组也可以由 tracker进行调度选择。一个分组的存储服务器访问压力较大时,可以在该组增加存储服务器来扩充服务能力(纵向 扩容)。当系统容量不足时,可以增加组来扩充存储容量(横向扩容)。

3.Storage状态收集

Storage server会连接集群中所有的Tracker server,定时向他们报告自己的状态,包括磁盘剩余空间、文件同步 状况、文件上传下载次数等统计信息

三.文件上传流程


文件ID:group1/M00/00/00/rBEOeF5SfVeABqdKAADOcMloCIM691.jpg

客户端上传文件后存储服务器将文件ID返回给客户端,此文件ID用于以后访问该文件的索引信息。文件索引信息包 括:组名,虚拟磁盘路径,数据两级目录,文件名。

  • 组名:文件上传后所在的storage组名称,在文件上传成功后有storage服务器返回,需要客户端自行保存

  • 虚拟磁盘路径:storage配置的虚拟路径,与磁盘选项store_path*对应。如果配置了store_path0则是M00, 如果配置了store_path1则是M01,以此类推

  • 数据两级目录:storage服务器在每个虚拟磁盘路径下创建的两级目录,用于存储数据文

  • 文件名:与文件上传时不同。是由存储服务器根据特定信息生成,文件名包含:源存储服务器IP地址、文件创 建时间戳、文件大小、随机数和文件拓展名等信息。

四. 文件下载流程


Tracker(追踪服务器):根据请求的文件路径即文件ID 来快速定义文件

1.通过组名tracker能够很快的定位到客户端需要访问的存储服务器组是group1,并选择合适的存储服务器提供客 户端访问。

2.存储服务器根据“文件存储虚拟磁盘路径”和“数据文件两级目录”可以很快定位到文件所在目录,并根据文件名找到 客户端需要访问的文件

FastDFS-介绍篇相关推荐

  1. FastDFS介绍并在centos7中安装

    文章目录 FastDFS介绍 什么是FastDFS FastDFS安装 一.安装gcc环境libfastcommon 二.安装FastDFS 三.编辑tracker.conf: 四.修改storage ...

  2. 国人之光-分布式存储框架FastDFS入门篇

    一.分布式文件存储 1.分布式文件存储的由来   在我们的项目中有很多需要存储的内容出现,比如图片,视频,文件等等,在早期的时候用户量不大,产生的文件也不是很多,这时我们可以把文件和服务程序放在一个服 ...

  3. Moebius实现Sqlserver集群~介绍篇

    今年是一个不平凡的一年,接触到了很多新艳的,让人兴奋的东西,虽然自己的牙掉了两颗,但感觉自己又年青了两岁,哈哈!进入正题,今年公司开始启用数据库集群,对于Sqlserver来说,实现方式并不是很多,一 ...

  4. 当前订单不支持只花呗支付是什么意思_1、(跑腿介绍篇)支付宝花呗分期线下推广...

    这篇文章主要讲第1篇<花呗分期跑腿介绍篇> 我会以问答的形式,来为大家介绍花呗分期这个业务. 一.花呗分期是什么? 花呗分期是支付宝官方推出的,为了重点宣传花呗分期线下用户去使用开展的活动 ...

  5. Kubernetes系列之Helm介绍篇

    本次系列使用的所需部署包版本都使用的目前最新的或最新稳定版,安装包地址请到公众号内回复[K8s实战]获取 介绍 Helm 是 Deis 开发的一个用于 Kubernetes 应用的包管理工具,主要用来 ...

  6. MonoRail学习-介绍篇(一)

    MonoRail学习-介绍篇 刚刚结束了使用Castle MonoRail的一个项目,所以想将在项目中的一些片段大家一起共享一样.由于这是一个网站项目,所以使用Monorail,因为他使用MVC模式, ...

  7. JEECG Excel 介绍篇

    Excel 介绍篇 AutoPOI 模块可以提供Excel导入导出(支持单表,一对多模型),支持2003和2007的模板,同时支持使用模板的导出 excel导出的的学习成本降低非常低,一般的报表也可以 ...

  8. 负载均衡原理剖析与实践:负载均衡第一篇-介绍篇

    负载均衡第一篇-介绍篇   系列文章索引: 负载均衡第一篇-介绍篇 负载均衡第二篇-负载均衡基础知识普及   前言:相信朋友们对负载均衡应该不陌生了!特别是对搞运维的朋友!可能很多的技术人员认为,负载 ...

  9. FastDFS介绍与安装配置

    FastDFS由国人设计开发,是一个开源的轻量级分布式文件系统,采用tracker和storage完成对文件的分布式存储管理,实现对文件访问的负载均衡. 一.FastDFS介绍 FastDFS服务端有 ...

  10. Percona XtraBackup 安装介绍篇

    XtraBackup介绍 XtraBackup是Percona公司的开源项目,用以实现类似Innodb官方的热备份工具InnoDB Hot Backup的功能,它支持在线热备份(备份时不影响数据读写) ...

最新文章

  1. css如何清除浮动(二)
  2. asp.net core mvc 异步表单(Ajax.BeginForm)
  3. FPL 2017最佳论文:如何对FPGA云发动DoS攻击?
  4. Java 9模块系统(拼图)@ LJC的HackTheTower
  5. php 运行外部程序_PHP在linux上执行外部命令的方法
  6. 目标检测论文阅读:Multi-scale Location-aware Kernel Representation for Object Detection(CVPR2018)
  7. Adobe Dreamweaver CC完美补丁amtlib.dll 解决进程CPU占用高问题
  8. 20170223找女朋友之路思考总结
  9. 学生党必备读书笔记app推荐
  10. archlinux+i3wm安装与配置
  11. [JavaScript]只需一行代码,轻松搞定快捷留言-V2升级版javascript
  12. S3C2440上LCD驱动(FrameBuffer)实例开发讲解(一)
  13. 程序员必知的 4 种命名方式
  14. Ubuntu关于串口的操作(查看串口信息、串口助手、串口权限)
  15. JAVA实现PCA主成分分析_主成分分析PCA(principal component analysis)原理
  16. c语言程序设计刘会超答案,C语言程序设计案例教程
  17. 基于U-Net的眼底图像血管分割实例
  18. ios应用程序加载分析(二)
  19. 嗨CE系列教程全套(入门,进阶,高阶)游戏驱动反调试
  20. Fastreid 代码

热门文章

  1. quartus 固化程序步骤
  2. c语言define变量字符串拼接,C语言#define的用法
  3. linux下如何模拟按键输入和模拟鼠标?
  4. 实际项目中如何使用Git做分支管理
  5. 直角坐标XY和经纬度BL正算反算(西安80坐标3度分带)php
  6. 热敏电阻(NTC)温度计算,C语言
  7. 大咖对话 | 企业数字化转型破局之道
  8. java代码实现曼彻斯特编码
  9. 【走出自律误区】—这一刻的松懈,能否决定我的一生?
  10. 无线接收信号强度(RSSI)那些事儿