我在数据库中有一个提要列表,用于从 FTP 服务器下载 XML 文件,然后对其进行解析。该脚本被捆绑到一个 jar 文件中,该文件每天使用 Windows 任务计划程序运行。有时,请求会在抓取某个 xml 文件时被拖走。到目前为止,它在 2 周内发生了大约 3 次,我看不到真正的模式。
当它出现问题时,我转到运行它的计算机,我看到命令窗口打开,并且在 xml 完全下载之前停止。如果我关闭命令窗口并手动运行任务,一切都会正常工作。
我用来下载 xml 文件的代码是:
private void loadFTPFile(String host, String username, String password, String filename, String localFilename){
System.out.println(localFilename);
FTPClient client = new FTPClient();
FileOutputStream fos = null;
try {
client.connect(host);
client.login(username, password);
String localFilenameOutput = createFile(assetsPath + localFilename);
fos = new FileOutputStream(localFilenameOutput);
client.retrieveFile(filename, fos);
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (fos != null)
fos.close();
client.disconnect();
} catch (IOException e) {
e.printStackTrace();
}
}
}
这个函数在循环中被调用,当它失败时,一切都会停止,脚本不会进入下一个提要。
我不确定发生了什么,可能连接丢失,但我认为如果发生这种情况,try/catch 会捕获。我不确定超时是否可以解决问题或需要使用线程(但我从未使用过线程)
谁能指出我正确的方向为什么会发生这种情况以及我可以做些什么来解决这个问题