FastDFS

1、简介

FastDFS是以C语言开发一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储、文件同步、文件访问(文件上传、文件下载)等,解决了大容量存储和负载均衡的问题。特别适合以文件为载体的在线服务,如相册网站、视频网站等等。
FastDFS为互联网量身定制,充分考虑了荣誉备份、负载均衡、先行扩容等机制,并注重高可用,高性能等指标,使用FastDFS很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务。
分布式文件系统:
基于客户端/服务器的文件存储系统,对等特性允许其他客户机访问的目录,一旦被访问,这个目录对客户机来说就像使用本地驱动器一样。

2、构成

FastDFS由跟踪服务器(Tracker Server)、存储服务器(Storage Server)和客户端(Client)构成

Tracker Servr追踪服务器
追踪服务器负责接收客户端的请求,选择合适的组合storage server, tracker server与storage server之间也会用心跳机制来检测对方是否活着
Tracker需要管理的信息也都放在内存中,并且里面所有的Tracker都是对等的(每个节点地位相等),很容易扩展
客户端访问集群的时候会随机分配一个Tracker来和客户端交互。
Storage Server存储服务器
实际存储数据,分成若干组(group),实际tracker就是管理的stoage中的组,而组内机器中则存储数据,group可以隔离不同应用的数据,不同的应用的数据刚在不同group里面

优点:
海量的存储:主从型纷纷不是存储,存储空间方便拓展,FastDFS
对文件内容做hash处理,避免出现重复文件,然后FastDFS结合Nginx集成,提供网站效率
客户端Client
主要是上传下载数据的服务器,也就是我们自己的项目所部署在的服务器。每个客户端服务器都需要安装Nginx
在这里插入图片描述

3、读写操作

写入数据
写操作的时候,storage会将他所挂载的所有数据存储目录的底下都创建2级子目录,每一级256个,总共65536个,新写的文件会以hash的方式被路由到某个子目录下,然后将文件数据作为本地文件存储到该目录中。
在这里插入图片描述
下载文件
当客户端向Tracker发起下载请求时,并不会直接下载,而是先查询storage server(检测同步状态),返回storage server的ip和端口,然后客户端会带着文件信息(组名,路径,文件名),去访问相关的storage,然后下载文件。
在这里插入图片描述
使用

详细安装使用:https://cloud.tencent.com/developer/article/1459349

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值