Bug解决 | com.github.tobato.fastdfs.exception.FdfsConnectException: 无法获取服务端连接资源 端口号为0
若没有变化,可能需要关闭终端重新打开。可以看到当前目录下安装了两个版本的。
问题描述
使用腾讯云主机,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;
}
}
这样不太优雅,但是暂时解决了这个问题,之后有更好的解决方案再来更新~
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)