我有一个数据库中的源列表,用于从FTP服务器下载
XML文件然后解析它. scrpt捆绑到一个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();
}
}
}
这个函数在循环中被调用,当它失败时,一切都停止,脚本不会进入下一个feed.
我不确定发生了什么,可能连接丢失,但我认为如果发生这种情况,try / catch会捕获.我不确定是否会超时或需要使用线程(但我从未使用线程)
任何人都可以指出我正确的方向为什么会发生这种情况以及我可以做些什么来解决这个问题