现象:completePendingCommand方法假死,导致请求一直没有返回参数,最终导致超时
过程记录:在一个文件下载上传的接口中,用到了FTPClient,在FTP下载流文件然后上传到影像系统,在测试时,故意取不到文件等着报错时,接口却迟迟没有返回任何信息,然后断点找问题,发现代码进入completePendingCommand就出不来了。
代码前面用到了ftpClient.retrieveFileStream(fileName)方法,一切正常的话,会返回文件流inputStream,大家都会在使用完FTPClient后关闭,就是这,如果因为inputStream返回的null一直没有执行inputStream.close()方法,且执行了FTPClient.completePendingCommand(),那就会发生了假死挂机现象。
总之:completePendingCommand()会一直在等FTP Server返回226 Transfer complete,但是FTP Server只有在InputStream执行close方法时,才会返回。所以先要执行close方法,再执行completePendingCommand