java sftp下载文件报错 Caused by: com.jcraft.jsch.JSchException: session is down

最近线上有一个下载文件的报错:Caused by: com.jcraft.jsch.JSchException: session is down

业务场景是我们使用jsch连接到三方提供的一个sftp服务器,每日定时下载所需的文件。

   <dependency>
       <groupId>com.jcraft</groupId>
       <artifactId>jsch</artifactId>
       <version>0.1.51</version>
    </dependency>

最近线上突然报了Caused by: com.jcraft.jsch.JSchException: session is down错误,导致文件都没有下载下来,这块因为是老业务很长时间都没动过,跟三方确认,他们也没有做过任何改动。

        然后三方查询反馈,我们跟他们文件服务器的已建立的连接有很多,有500多个连接(产生了连接泄露)

netstat -ant|grep 三方ip | awk '/^tcp/ {++S[$NF]} END {for(a in S) print (a,S[a])}'

通过我分析我们判断,是已建立的连接数达到了最大值,后续再创建的连接都报错,无法连接。

紧急解决方案,我们通过重启服务,联接断开后,再重试业务,正常联接,文件也正常下载到.

事后我们,通过代码分析,确实有一些问题,在业务处理过程中,没有正常关闭连接。导致随着时间推移,连接越来越多,最终达到上限,而不能正常连接

这里给出一些使用建议:

1.创建的连接,使用后应该立即关闭,要在finally代码块进行关闭连接

2.真正在使用阶段再创建连接,不要过早的创建,避免创建后因为不使用,又忘记关闭连接(我们线上就是这种情况)

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,你遇到的问题是`Caused by: com.jcraft.jsch.JSchException: Session.connect: java.net.SocketException: Connection reset`。这个错误通常是由于网络连接问题引起的。可能有以下几个原因导致这个错误: 1. 服务器端口未打开或被防火墙阻止:请确保你的SFTP服务器端口已正确打开,并且没有被防火墙阻止。 2. 服务器地址错误:请确保你的SFTP服务器地址是正确的,可以尝试使用ping命令来测试服务器的连通性。 3. 服务器连接超时:如果服务器连接超时,可能是由于网络延迟或服务器负载过高导致的。你可以尝试增加连接超时时间或者优化服务器性能。 4. 客户端配置错误:请确保你的Java代码中的SFTP配置是正确的,包括服务器地址、端口、用户名、密码等。 以下是一个示例代码,演示了如何使用JSch库进行SFTP上传文件: ```java import com.jcraft.jsch.*; public class SftpExample { public static void main(String[] args) { String host = "sftp.example.com"; int port = 22; String username = "your-username"; String password = "your-password"; String localFilePath = "/path/to/local/file.txt"; String remoteFilePath = "/path/to/remote/file.txt"; try { JSch jsch = new JSch(); Session session = jsch.getSession(username, host, port); session.setPassword(password); session.setConfig("StrictHostKeyChecking", "no"); session.connect(); ChannelSftp channel = (ChannelSftp) session.openChannel("sftp"); channel.connect(); channel.put(localFilePath, remoteFilePath); channel.disconnect(); session.disconnect(); } catch (JSchException | SftpException e) { e.printStackTrace(); } } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值