docker部署FastDFS整合Springboot

1、FastDFS是什么?

FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储、文件同步、文件访问(文件上传、文件下载)等,解决了大容量存储和负载均衡的问题。特别适合以文件为载体的在线服务,如相册网站、视频网站等等。
FastDFS为互联网量身定制,充分考虑了冗余备份、负载均衡、线性扩容等机制,并注重高可用、高性能等指标,使用FastDFS很容易搭建一套高性能的文件服务器集群提供文件上传、下载等服务

2、搭建docker环境

参考文章:

https://blog.csdn.net/JiuMen3520/article/details/134336301

3、部署fastdfs

1、搜索fastdfs镜像
docker search fastdfs
2、下载镜像
方法一(直接拉取):
docker pull morunchang/fastdfs

方法二(百度网盘下载):
链接:https://pan.baidu.com/s/1pAS_wOFJrpk-BlNs3lZYfQ?pwd=bfmu 
提取码:bfmu

若选择方法二,执行docker导入镜像命令:
docker load -i fastdfs_latest.tar
3、启动tracker
docker run -d --name tracker --net=host morunchang/fastdfs sh tracker.sh
4.启动storage
(1)宿主机创建目录(用于磁盘挂载)
mkdir /data/fastDFS/data
(2)执行启动命令
docker run -v /data/fastDFS/data:/data/fast_data/data/00/00 -d --name storage --net=host -e TRACKER_IP=服务器访问IP:22122 -e GROUP_NAME=group1 morunchang/fastdfs sh storage.sh

启动效果:
在这里插入图片描述
修改nginx配置

1.进入storage
    docker exec -it storage容器id /bin/bash
 
2.找到nginx配置
    whereis nginx --->会看到目录在/etc/nginx/下
 
3.修改nginx配置
    vi /etc/nginx/conf/nginx.conf
 
4.修改监听端口(listen)和访问地址(server_name),我这将端口修改为了80,访问地址为公网ip
 
5.退出容器
    exit 
 
6.重启 storage
    docker restart storage容器id

4、整合springboot

(1)新建springboot项目
(2)加入maven依赖

   <!-- FastDFS -->
   <dependency>
       <groupId>com.github.tobato</groupId>
       <artifactId>fastdfs-client</artifactId>
   </dependency>

在这里插入图片描述
(3)修改配置文件yml

# FastDFS配置
fdfs:
  domain: http://服务器IP
  soTimeout: 3000
  connectTimeout: 2000
  trackerList: 服务器IP:22122

在这里插入图片描述
(3)创建controller类

package com.pie.file.controller;

import com.pie.common.core.domain.R;
import com.pie.common.core.utils.file.FileUtils;
import com.pie.file.service.ISysFileService;
import com.pie.system.api.domain.SysFile;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

/**
 * 文件请求处理
 * 
 * @author p
 */
@RestController
public class SysFileController
{
    private static final Logger log = LoggerFactory.getLogger(SysFileController.class);

    @Autowired
    private ISysFileService sysFileService;

    /**
     * 文件上传请求
     */
    @PostMapping("upload")
    public R<SysFile> upload(MultipartFile file)
    {
        try
        {
            // 上传并返回访问地址
            String url = sysFileService.uploadFile(file);
            SysFile sysFile = new SysFile();
            sysFile.setName(FileUtils.getName(url));
            sysFile.setUrl(url);
            return R.ok(sysFile);
        }
        catch (Exception e)
        {
            log.error("上传文件失败", e);
            return R.fail(e.getMessage());
        }
    }
}

(4)创建service接口

package com.pie.file.service;

import org.springframework.web.multipart.MultipartFile;

/**
 * 文件上传接口
 * 
 * @author p
 */
public interface ISysFileService
{
    /**
     * 文件上传接口
     * 
     * @param file 上传的文件
     * @return 访问地址
     * @throws Exception
     */
    public String uploadFile(MultipartFile file) throws Exception;
}

(5)创建serviceImpl实现类

package com.pie.file.service;

import java.io.InputStream;
import com.alibaba.nacos.common.utils.IoUtils;
import com.pie.common.core.utils.file.FileTypeUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Primary;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;
import com.github.tobato.fastdfs.domain.fdfs.StorePath;
import com.github.tobato.fastdfs.service.FastFileStorageClient;

/**
 * FastDFS 文件存储
 *
 * @author p
 */
@Primary
@Service
public class FastDfsSysFileServiceImpl implements ISysFileService
{
    /**
     * 域名或本机访问地址
     */
    @Value("${fdfs.domain}")
    public String domain;

    @Autowired
    private FastFileStorageClient storageClient;

    /**
     * FastDfs文件上传接口
     *
     * @param file 上传的文件
     * @return 访问地址
     * @throws Exception
     */
    @Override
    public String uploadFile(MultipartFile file) throws Exception
    {
        InputStream inputStream = file.getInputStream();
        StorePath storePath = storageClient.uploadFile(inputStream, file.getSize(),
                FileTypeUtils.getExtension(file), null);
        IoUtils.closeQuietly(inputStream);
        return domain + "/" + storePath.getFullPath();
    }
}

5、接口测试

使用postman访问接口测试

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

参考文章

参考文章

  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以按照以下步骤来部署 FastDFS: 1. 下载 FastDFS Docker 镜像:`docker pull season/fastdfs` 2. 创建一个容器网络:`docker network create fastdfs` 3. 启动 FastDFS Tracker 服务器容器: ``` docker run -d --name tracker --net=fastdfs --ip 172.18.0.2 \ -v {local_path}/tracker:/fastdfs/tracker/storage \ -e TRACKER_PORT=22122 \ season/fastdfs sh tracker.sh ``` 其中: - `{local_path}` 是本地路径,需要将其替换为宿主机上的实际路径。 - `TRACKER_PORT` 是 Tracker 服务器的端口号,默认为 22122。 4. 启动 FastDFS Storage 服务器容器: ``` docker run -d --name storage --net=fastdfs --ip 172.18.0.3 \ -v {local_path}/storage:/fastdfs/storage/data \ -e TRACKER_SERVER=tracker:22122 \ -e GROUP_NAME=group1 \ -e STORAGE_PORT=23000 \ -e STORAGE_HTTP_PORT=8888 \ season/fastdfs sh storage.sh ``` 其中: - `{local_path}` 是本地路径,需要将其替换为宿主机上的实际路径。 - `TRACKER_SERVER` 是 Tracker 服务器地址和端口号,格式为 `ip:port` 或者 `hostname:port`。 - `GROUP_NAME` 是存储组的名称,默认为 `group1`。 - `STORAGE_PORT` 是 Storage 服务器的端口号,默认为 23000。 - `STORAGE_HTTP_PORT` 是 Storage 服务器的 HTTP 端口号,默认为 8888。 5. 在 FastDFS Web 界面中查看文件存储情况: 访问 `http://{ip}:8888/groupName`,其中 `{ip}` 是 Storage 服务器的 IP 地址,`groupName` 是存储组的名称。 以上就是部署 FastDFS 的基本步骤,需要注意的是,启动 Storage 服务器容器的时候需要指定 Tracker 服务器的地址和端口号,否则 Storage 服务器无法加入到 FastDFS 集群中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值