问题描述
使用腾讯云主机,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;
}
}
这样不太优雅,但是暂时解决了这个问题,之后有更好的解决方案再来更新~