我们在使用FastDFS部署一个分布式文件系统的时候,通过FastDFS的客户端API来进行文件的上传、下载、删除等操作。同时通过FastDFS的HTTP服务器来提供HTTP服务。但是FastDFS的HTTP服务较为简单,无法提供负载均衡等高性能的服务,所以FastDFS的开发者——淘宝的架构师余庆同学,为我们提供了Nginx上使用的FastDFS模块(也可以叫FastDFS的Nginx模块)。其使用非常简单。
FastDFS通过Tracker服务器,将文件放在Storage服务器存储,但是同组之间的服务器需要复制文件,有延迟的问题.假设Tracker服务器将文件上传到了192.168.1.80,文件ID已经返回客户端,这时,后台会将这个文件复制到192.168.1.30,如果复制没有完成,客户端就用这个ID在192.168.1.30取文件,肯定会出现错误。这个fastdfs-nginx-module可以重定向连接到源服务器取文件,避免客户端由于复制延迟的问题,出现错误。
FastDFS系统结构如下图所示:

Nginx结合FastDFS的系统结构如下图所示:

本文介绍如何利用FastDFS的Nginx模块解决文件复制延迟问题,提高分布式文件系统的性能。FastDFS通过Tracker服务器分配文件存储在Storage服务器上,但同组服务器间文件复制存在延迟,Nginx模块能重定向请求至源服务器,确保文件即时可用。
1520

被折叠的 条评论
为什么被折叠?



