一、介绍
    1、体系结构
    FastDFS 架构包括 Tracker server 和 Storage server。客户端请求 Tracker server 进行文件上传、下载,通过Tracker server 调度最终由 Storage server 完成文件上传和下载。
    Tracker server 作用是负载均衡和调度,通过 Tracker server 在文件上传时可以根据一些策略找到Storage server 提供文件上传服务。可以将 tracker 称为追踪服务器或调度服务器。Storage server 作用是文件存储,客户端上传的文件最终存储在 Storage 服务器上,Storageserver 没有实现自己的文件系统而是利用操作系统的文件系统来管理文件。可以将storage称为存储服务器。
    1559117928459.png
    2、上传流程
    image-20211013013254634.png客户端上传文件后存储服务器将文件 ID 返回给客户端,此文件 ID 用于以后访问该文件的索引信息。文件索引信息包括:组名,虚拟磁盘路径,数据两级目录,文件名。
    eg: group1/M00/00/00/asdfsadfsadfsadfsadfsadfsa.png
    *组名:文件上传后所在的 storage 组名称,在文件上传成功后有storage 服务器返回,需要客户端自行保存。
    *虚拟磁盘路径:storage 配置的虚拟路径,与磁盘选项store_path对应。如果配置了
    /data/00-ff/00-ff/——->/M00
    /data2——>/M01
    *数据两级目录:storage 服务器在每个虚拟磁盘路径下创建的两级目录,用于存储数据
    文件。
    *文件名:与文件上传时不同。是由存储服务器根据特定信息生成,文件名包含:源存储
    服务器 IP 地址、文件创建时间戳、文件大小、随机数和文件拓展名等信息。

    3、fastDFS搭建
    我们使用Docker搭建FastDFS的开发环境
    拉取镜像

    1. docker pull morunchang/fastdfs

    运行tracker

    1. docker run -d --name tracker --net=host morunchang/fastdfs sh tracker.sh

    运行storage

    1. docker run -d --name storage --net=host -e TRACKER_IP=<your tracker server address>:22122 -e GROUP_NAME=<group name> morunchang/fastdfs sh storage.sh
    • 使用的网络模式是–net=host, 替换为你机器的Ip即可
    • 是组名,即storage的组
    • 如果想要增加新的storage服务器,再次运行该命令,注意更换 新组名

    (4)修改nginx的配置
    进入storage的容器内部,修改nginx.conf

    1. docker exec -it storage /bin/bash

    进入后

    1. vi /data/nginx/conf/nginx.conf

    添加以下内容

    1. location /group1/M00 {
    2. proxy_next_upstream http_502 http_504 error timeout invalid_header;
    3. proxy_cache http-cache;
    4. proxy_cache_valid 200 304 12h;
    5. proxy_cache_key $uri$is_args$args;
    6. proxy_pass http://fdfs_group1;
    7. expires 30d;
    8. }

    (5)退出容器

    1. exit

    (6)重启storage容器

    1. docker exec -it storage /bin/bash