问题描述

使用腾讯云主机,Nginx结合FastDFS搭建文件服务器,在云主机上测试了文件上传功能一切正常。22122端口与23000端口都开放了,但是在SpringBoot项目中测试上传文件接口却报错:

2024-05-03 23:24:43.184 WARN 329860 — [nio-8080-exec-8] .m.m.a.ExceptionHandlerExceptionResolver : Resolved [com.github.tobato.fastdfs.exception.FdfsConnectException: 无法获取服务端连接资源:can’t create connection to/xx.232.168.22:0]

并且很奇怪的是这里显示的端口是0,猜测是端口的问题。在项目application.yaml文件中明明配置了FastDFS服务器的主机和IP,看起来并没有生效:

fdfs:
  tracker-list: xx.232.168.22:22122
  soTimeout: 6000
  connect-timeout: 6000

百思不能其解。

解决方案

方法一、 修改fastdfs-client版本

看到有人评论说是引入的fastdfs-client版本问题,在新版本中有这个Bug,以下是我在pom文件中引入的依赖:

<dependency>
    <groupId>com.github.tobato</groupId>
    <artifactId>fastdfs-client</artifactId>
    <version>1.27.2</version>
</dependency>

测试了几个版本后还没有成功,不清楚要改成什么版本可以解决这个问题。

方法二、手动设定trackerClient端口号

另一种方法是在项目中手动指定trackerClient的端口号,新建一个类名为UserDefaultTrackerClint,并重写两个关键方法,将返回结果设置端口号为23000即可解决。

@Primary
@Component("UserDefaultTrackerClient")
public class UserDefaultTrackerClint extends DefaultTrackerClient {
    @Override
    public StorageNode getStoreStorage(String groupName) {
        StorageNode result = super.getStoreStorage(groupName);
        result.setPort(23000);
        return result;
    }

    @Override
    public StorageNodeInfo getUpdateStorage(String groupName, String filename) {
        StorageNodeInfo result = super.getUpdateStorage(groupName, filename);
        result.setPort(23000);
        return result;
    }
}

这样不太优雅,但是暂时解决了这个问题,之后有更好的解决方案再来更新~

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐