快捷搜索: 王者荣耀 脱发

FastDFS为什么要用Nginx做代理

一、FastDFS简要介绍

1.是什么

FastDFS就是一种轻量级的、常用的分布式文件系统,通常用作图片服务器。

2.两个部分都是干什么的

FastDFS分为两个部分,Tracker和Storage。

Tracker作为协调者,用户上传和下载文件都要通过tracker。

Storage是存储节点,主要用来存储文件。storage可以分成多个组,每个组有若干个节点,这些节点放的文件都是一样的。各个组存放的文件都是不一样的。所以,如果想扩充FastDFS的容量,非常方便,直接添加组就行了。

3.用户上传和下载文件的具体过程

文件上传过程

文件下载过程

二、FastDFS和Nginx结合使用

1.对tracker做负载均衡

为了承载更高的并发量,tracker可以做成集群。需要使用nginx做负载均衡。

2.nginx插件fastdfs-nginx-module的作用

FastDFS通过Tracker服务器,将文件放在某个Storage服务器存储,但是同组Storage存储服务器之间需要进入文件复制,有同步延迟的问题。

假设Tracker服务器将文件上传到了Storage Server 11,上传成功后文件ID已经返回给客户端。此时FastDFS存储集群机制会将这个文件同步到同组存储Storage Server 12,在文件还没有复制完成的情况下,客户端如果用这个文件ID在Storage Server 12上取文件,就会出现文件无法访问的错误。 (Storage Server 11和Storage Server 12是同一个storage组)

而fastdfs-nginx-module可以重定向文件连接到文件上传时的源服务器(Storage Server 11)取文件,避免客户端由于复制延迟导致的文件无法访问错误 。

经验分享 程序员 微信小程序 职场和发展