前言
本节内容我们使用docker-compose一键式搭建一套fastdfs服务,实现docker环境下的文件存储服务,在开始本节内容之前,我们需要提前安装好docker和docker-compose环境。fastdfs是一套分布式的文件存储服务系统,主要有tracker和storage俩大组件组成,tracker服务完成文件的调度和管控,storage主要用来存储文件和备份。本机内容使用的docker镜像是season/fastdfs:1.2。
正文
①docker-compose环境下的fastdfs服务安装脚本fastdfs.yml
version: "3.3"
####################fastdfs搭建#################################################
services:
fastdfs-tracker:
hostname: fastdfs-tracker
image: season/fastdfs:1.2
container_name: atp-fastdfs-tracker
restart: "no"
volumes:
- /usr/local/bin/ht-atp/fastdfs/tracker/data:/fastdfs/tracker/data
- /usr/local/bin/ht-atp/fastdfs/tracker/conf:/etc/fdfs
network_mode: "host"
command: tracker
fastdfs-storage:
hostname: fastdfs-storage
image: season/fastdfs:1.2
container_name: atp-fastdfs-storage
restart: "no"
depends_on:
- fastdfs-tracker
volumes:
- /usr/local/bin/ht-atp/fastdfs/fdfs_conf/storage.conf:/fdfs_conf/storage.conf
- /usr/local/bin/ht-atp/fastdfs/storage/data:/fastdfs/storage/data
- /usr/local/bin/ht-atp/fastdfs/store_path:/fastdfs/store_path
network_mode: "host"
environment:
- TRACKER_SERVER=192.168.110.88:22122
command: storage
fastdfs-nginx:
hostname: fastdfs-storage
image: season/fastdfs:1.2
container_name: atp-fastdfs-nginx
restart: "no"
volumes:
- /usr/local/bin/ht-atp/fastdfs/nginx/conf/nginx.conf:/etc/nginx/conf/nginx.conf
- /usr/local/bin/ht-atp/fastdfs/store_path:/fastdfs/store_path
depends_on:
- fastdfs-storage
network_mode: "host"
environment:
- TRACKER_SERVER=192.168.110.88:22122
command: nginx
②tracker服务映射目录创建
命令:
- mkdir -p /usr/local/bin/ht-atp/fastdfs/tracker/data
- mkdir -p /usr/local/bin/ht-atp/fastdfs/tracker/conf
③storage服务映射目录创建
命令:
服务数据存储目录:mkdir -p /usr/local/bin/ht-atp/fastdfs/storage/data
文件存储目录:mkdir -p /usr/local/bin/ht-atp/fastdfs/store_path
④ nginx服务配置文件映射目录创建及配置文件创建
命令:
创建nginx映射目录: mkdir -p /usr/local/bin/ht-atp/fastdfs/nginx/conf创建nginx配置文件:touch nginx.conf
⑤配置nginx代理,使用http访问文件存储服务资源nginx.conf
#user nobody; worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name localhost; #fastdfs代理,通过http访问上传资源 location /group1/M00 { root /fastdfs/store_path; ngx_fastdfs_module; } } }
⑥使用docker-compose一键式启动fastdfs服务
命令:docker-compose -f fastdfs.yml up -d
⑦使用portainer查看fastdfs服务
⑧springboot项目集成fastdfs,通过接口上传文件到fastdfs
ps:关于springboot集成fastdfs请关注作者往期博客
⑨查看上传的文件存储位置
⑩使用nginx代理,通过http访问fastdfs上的文件资源
结语
至此,关于docker-compose一键式搭建fastdfs文件存储服务系统到这里就结束了,下期见。。。