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;
    }
}

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

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值