当前位置:网站首页>FastDFS 一文读懂
FastDFS 一文读懂
2022-08-03 23:43:00 【在奋斗的大道】
目录
FastDFS 介绍
FastDFS 概念
FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储、文件同步、文件访问(文件上传、文件下载)等,解决了大容量存储和**负载均衡**的问题。特别适合以文件为载体的在线服务,如相册网站、视频网站等等。
FastDFS为互联网量身定制,充分考虑了冗余备份、负载均衡、在线扩容等机制,并注重高可用、高性能等指标,使用FastDFS很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务。
FastDFS 作用
适合用来存储用户图片、视频、文档等文件。 出于简洁考虑,FastDFS没有对文件做分块存储,因此不太适合分布式计算场景。
FastDFS 优缺点
优点:
- 适合中小文件存储(建议范围:
4KB<file_size<500MB) - 主备Tracker服务,增强系统的可用性
- 系统不需要支持POSIX,这样的话就降低了系统的复杂度,使得处理的速度会更高
- 支持主从文件,支持自定义扩展名
- 支持在线扩容机制,增强了系统的可扩展性
- 实现了软RAID,增强了系统的并发处理能力和数据容错恢复能力
缺点:
- 直接按文件存储,可直接读取文件内容,缺乏文件安全性
- 通过API下载,存在单点的性能瓶颈
- 不支持断点续传,对大文件将是噩梦
- 同步机制不支持文件正确性校验,降低了系统的可用性
- 不支持POSIX通用接口访问,通用性比较的低
- 对跨公网的文件同步,存在着比较大的延迟,需要应用做相应的容错策略
FastDFS 相关概念
FastDFS服务端有三个角色:跟踪服务器(tracker server)、存储服务器(storage server)和客户端(client)。
tracker server:跟踪服务器,主要做调度工作,起负载均衡的作用。Tracker是FastDFS的协调者,负责管理所有的storage server和group,每个storage在启动后会连接Tracker,告知自己所属的group等信息,并保持周期性的心跳,tracker根据storage的心跳信息,建立group==>[storage server list]的映射表。
storage server:存储服务器(又称:存储节点或数据服务器),文件和文件属性(meta data)都保存到存储服务器上。Storage server直接利用OS的文件系统调用管理文件。
client:客户端,作为业务请求的发起方,通过专有接口,使用TCP/IP协议与跟踪器服务器或存储节点进行数据交互。FastDFS向使用者提供基本文件访问接口,比如upload、download、append、delete等,以客户端库的方式提供给用户使用。
FastDFS 原理
FastDFS系统拓扑图

FastDFS分为Tracker、Storage,其中Storage负责存储文件,Tracker负责存储文件所在地址,主要作用是负载均衡和资源调度。
Tracker、Storage都可以实现集群部署,Tracker的每个节点地位平等,而Storage可以分为多个组,每个组之间保存的文件是不同的,组内部分为多个成员,每个成员保存的内容是一样,组成员地位一致,没有主从概念。
使用FastDFS存储文件优点:可以应对互联网的海量文件存储,一旦文件较多,可以随时横向扩展,且集群的实现也使系统不存在单点故障问题,用户不会因为服务器宕机而无法访问文件资源。
FastDFS核心工作流程
FastDFS 文件上传

1. client询问tracker上传到的storage,不需要附加参数;
2. tracker返回一台可用的storage;
3. client直接和storage通讯完成文件上传。
FastDFS 文件下载

Client询问tracker下载文件的storage,参数为文件标识(组名和文件名);
Tracker返回一台可用的storage;
Client直接和storage通讯完成文件下载。
Linux 环境搭建FastDFS
请参考:Centos 搭建FastDFS 分布式文件服务器搭建
Docker 环境搭建FastDFS
请参考: Docker 搭建FastDFS文件系统
SpringBoot 封装FastDFS 功能模块
边栏推荐
- End-to-End Lane Marker Detection via Row-wise Classification
- 【LeetCode】最长公共子序列(动态规划)
- BMN: Boundary-Matching Network for Temporal Action Proposal Generation阅读笔记
- - the skip/skipif Pytest learning
- V8中的快慢数组(附源码、图文更易理解)
- 用栈实现队列
- rosbridge-WSL2 && carla-win11
- CAS: 178744-28-0, mPEG-DSPE, DSPE-mPEG, methoxy-polyethylene glycol-phosphatidylethanolamine supply
- Creo 9.0在草图环境中创建坐标系
- 重新认识浏览器的渲染过程
猜你喜欢

国内首发可视化智能调优平台,小龙带你玩转KeenTune UI

Click the icon in Canvas App to generate PDF and save it to Dataverse

BMN: Boundary-Matching Network for Temporal Action Proposal Generation Reading Notes

V8中的快慢数组(附源码、图文更易理解)

一文搞定 SQL Server 执行计划

ML之interpret:基于titanic泰坦尼克是否获救二分类预测数据集利用interpret实现EBC模型可解释性之全局解释/局部解释案例

Code Casual Recording Notes_Dynamic Programming_416 Segmentation and Subsetting

冰河又一MySQL力作出版(文末送书)!!

智能座舱的「交互设计」大战

ML之yellowbrick:基于titanic泰坦尼克是否获救二分类预测数据集利用yellowbrick对LoR逻辑回归模型实现可解释性(阈值图)案例
随机推荐
图论-虚拟节点分层建图
1067 Sort with Swap(0, i)
Creo 9.0二维草图的诊断:重叠几何
Kotlin - extension functions and operator overloading
代码重构:面向单元测试
The longest substring that cannot have repeating characters in a leetcode/substring
libnet
HNUCM 2022年暑假ACM搜索专项练习
七夕活动浪漫上线,别让网络拖慢和小姐姐的开黑时间
软件测试内卷严重,如何提升自己的竞争力呢?
Three.js入门详解
leetcode/子串中不能有重复字符的最长子串
走迷宫 BFS
A simple understanding of TCP, learn how to shake hands, wave hands and various states
jav一键生成数据库文档
complete binary tree problem
Creo 9.0二维草图的诊断:加亮开放端点
Zilliz 2023 Fall Campus Recruitment Officially Launched!
IELTS essay writing template
XSLT – 编辑 XML概述