【组件】FastDFS

什么是FastDFS

FastDFS 是用 c 语言编写的一款开源的分布式文件系统。FastDFS 为互联网量身定制, 充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用 FastDFS 很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务。
在这里插入图片描述

FastDFS 架构包括 Tracker serverStorage server。客户端请求 Tracker server进行文 件上传、下载,通过 Tracker server 调度最终由 Storage server 完成文件上传和下载。

  • Tracker server作用是负载均衡调度,通过 Tracker server 在文件上传时可以根据一些 策略找到 Storage server 提供文件上传服务。可以将 tracker 称为追踪服务器或调度服务器
  • Storage server 作用是文件存储,客户端上传的文件最终存储在 Storage 服务器上, Storageserver 没有实现自己的文件系统而是利用操作系统 的文件系统来管理文件。可以将 storage 称为存储服务器

服务端两个角色:

  • Tracker:管理集群,tracker 也可以实现集群。每个 tracker 节点地位平等。收集 Storage 集群的状态;
  • Storage:实际保存文件 Storage 分为多个组,每个组之间保存的文件是不同的。每 个组内部可以有多个成员,组成员内部保存的内容是一样的,组成员的地位是一致的,没有 主从的概念。

工作流程

在这里插入图片描述

上传文件

上传流程:

  • 用户发送上传图片请求,应用服务器向Tracker服务器查询、获取可用的Storage的ip和端口号;
  • 通过Storage的ip和端口号,向Storage中存储文件;
  • Storage服务器存储成功后,生成文件索引信息,返回给应用服务器,(文件索引信息包括:组名,虚拟磁盘路径,数据两级目录,文件名)
  • 应用服务器将文件索引信息存储在数据库

文件下载

下载流程:
注:分布式文件存储,需要借助Nginx来下载文件

  • 客户端访问网站,网页中图片src为Nginx的IP:端口号,从而向Nginx发出请求;
  • Nginx从FastDFS的Storage服务器获取到响应的文件,然后返回给浏览器。

使用场景和特点

  • 海量存储,存储容量扩展方便。
  • 文件内容重复,在存储之前会对文件内容校验,在FastDFS中只保存一份;
  • 结合nginx提高网站访问图片的效率
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值