commons2.0FTP组件开发上传时间过长程序假死解决方案

xiaoxiao2024-04-13  16

    在我前一篇blog中http://zhouzaibao.iteye.com/blog/352582 提到如果使用apache.org的commons组件开发的FTP服务器使用流的方式来向FTP服务器上传文件,如果上传文件的时间比较长,例如2个小时左右,会造成程序假死,也就是completePendingCommand()方法始终不能返回,介绍一下我在调试过程中遇到的问题。

    1.FTP服务器有控制连接和数据连接,我的猜测是在进行数据传输的过程中,数据连接一直工作,但是控制连接可能就处于空闲状态,造成被服务器主动关闭,因此不能正常返回。

    2.在网上也看了一些网友的介绍,说在调用completePendingCommand()方法时必须关闭输入输出流,而调用这个方法主要就是为了拿到服务器端的226相应(File OK)。

    3.我的方法再调用completePendingCommand()方法时,输入输出流确实已经关闭,所以上诉的第2点不适合我的程序。

    4.另外我对程序进行更改,不调用completePendingCommand()方法,直接返回 后,发现在后续的程序中,如果发送命令(如PASV)到服务器端,收到的响应为226 File receive OK.而后续的基本上都正常了。

 

    综合以上分析我采用如下的方法来处理:

    在关闭输入输出流后发送NOOP命令激活控制连接,然后调用completePendingCommand()方法返回。

    现在我测试的结果是,即使数据传输3个小时,也不会造成程序假死。

while((c = raf.read(bytes))!= -1){ out.write(bytes,0,c); localreadbytes+=c; if(localreadbytes / step != process){ process = localreadbytes / step; // System.out.println("上传进度:" + process); //汇报上传状态,汇报进度函数,自己实现 reportUploadPercent((int)process); } out.flush(); } raf.close(); out.close(); ftpClient.sendNoOp(); boolean result = ftpClient.completePendingCommand();  

 

 

相关资源:敏捷开发V1.0.pptx
转载请注明原文地址: https://www.6miu.com/read-5014945.html

最新回复(0)