文章目录

  • 一、FastDFS简介
  • 1.1.FastDFS体系结构
  • 1.2.上传流程
  • 二、FastDFS搭建
  • 2.1.安装FastDFS镜像
  • 2.1.1.下载镜像
  • 2.1.2.运行tracker
  • 2.1.3.运行storage
  • 2.2.配置nginx
  • 2.3.开启启动设置
  • 总结




一、FastDFS简介

1.1.FastDFS体系结构


FastDFS是一个开源的轻量级[分布式文件系统](https://baike.baidu.com/item/%E5%88%86%E5%B8%83%E5%BC%8F%E6%96%87%E4%BB%B6%E7%B3%BB%E7%BB%9F/1250388),它对文件进行管理,功能包括:文件存储、文件同步、文件访问(文件上传、文件下载)等,解决了大容量存储和负载均衡的问题。特别适合以文件为载体的在线服务,如相册网站、视频网站等等。

FastDFS为互联网量身定制,充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用FastDFS很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务。

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

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

FastDFS docker集群 docker部署fastdfs集群_FastDFS docker集群

1.2.上传流程

FastDFS docker集群 docker部署fastdfs集群_FastDFS docker集群_02


客户端上传文件后存储服务器将文件 ID 返回给客户端,此文件 ID 用于以后访问该文件的索引信息。文件索引信息包括:组名,虚拟磁盘路径,数据两级目录,文件名。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-00V8RI5q-1613971548465)(image\1559118013272.png)]

组名:文件上传后所在的 storage 组名称,在文件上传成功后有storage 服务器返回,需要客户端自行保存。

虚拟磁盘路径:storage 配置的虚拟路径,与磁盘选项store_path*对应。如果配置了

store_path0 则是 M00,如果配置了 store_path1 则是 M01,以此类推。

数据两级目录:storage 服务器在每个虚拟磁盘路径下创建的两级目录,用于存储数据

文件。

文件名:与文件上传时不同。是由存储服务器根据特定信息生成,文件名包含:源存储

服务器 IP 地址、文件创建时间戳、文件大小、随机数和文件拓展名等信息。

二、FastDFS搭建

2.1.安装FastDFS镜像

2.1.1.下载镜像

docker pull sevenyuan/fastdfs
docker images

FastDFS docker集群 docker部署fastdfs集群_服务器_03

2.1.2.运行tracker

docker run -it -d --name tracker --net=host -v /opt/docker/fastdfs/tracker/data:/data/fast_data sevenyuan/fastdfs sh tracker.sh

2.1.3.运行storage

docker run -d --name storage --net=host -v /opt/docker/fastdfs/storage/data:/data/fast_data -v /opt/docker/fastdfs/storage/store_path:/data/store_path -e TRACKER_IP=192.168.63.68:22122 -e GROUP_NAME=group1 sevenyuan/fastdfs sh storage.sh
  • 192.168.63.68是tracker容器的IP
  • group1是组名,即storage的组
  • 如果想要增加新的storage服务器,再次运行该命令,注意更换 新组名
  • 使用的网络模式是–net=host

2.2.配置nginx

Nginx在这里主要提供对FastDFS图片访问的支持,Docker容器中已经集成了Nginx,我们需要修改nginx的配置,进入storage的容器内部,修改nginx.conf

docker exec -it storage  /bin/bash

添加以下内容

location ~ /M00 {
     root /data/fast_data/data;
     ngx_fastdfs_module;
}

禁止缓存:

add_header Cache-Control no-store;

退出容器

exit

重启storage容器

docker restart storage

2.3.开启启动设置

docker update --restart=always tracker
docker update --restart=always storage

总结

后续会继续补充,欢迎留言