我有以下操作,每 3 秒运行一次。
基本上,它每 3 秒从服务器下载一个文件并将其保存到本地文件中。
下面的代码完成了一段时间的工作。
public class DownloadTask extends AsyncTask<String, Void, String>{
@Override
protected String doInBackground(String... params) {
downloadCommandFile( eventUrl);
return null;
}
}
private void downloadCommandFile(String dlUrl){
int count;
try {
URL url = new URL( dlUrl );
NetUtils.trustAllHosts();
HttpsURLConnection con = (HttpsURLConnection) url.openConnection();
con.setDoInput(true);
con.setDoOutput(true);
con.connect();
int fileSize = con.getContentLength();
Log.d(TAG, "Download file size = " + fileSize );
InputStream is = url.openStream();
String dir = Environment.getExternalStorageDirectory() + Utils.DL_DIRECTORY;
File file = new File( dir );
if( !file.exists() ){
file.mkdir();
}
FileOutputStream fos = new FileOutputStream(file + Utils.DL_FILE);
byte data[] = new byte[1024];
long total = 0;
while( (count = is.read(data)) != -1 ){
total += count;
fos.write(data, 0, count);
}
is.close();
fos.close();
con.disconnect(); // close connection
} catch (Exception e) {
Log.e(TAG, "DOWNLOAD ERROR = " + e.toString() );
}
}
一切正常,但如果我让它运行 5 到 10 分钟,我会收到以下错误。
06-04 19:40:40.872: E/NativeCrypto(6320): AppData::create pipe(2) 失败:打开的文件太多 06-04 19:40:40.892: E/NativeCrypto(6320): AppData::create管道(2)失败:打开的文件太多 06-04 19:40:40.892:E/EventService(6320):下载错误 = javax.net.ssl.SSLException:无法创建应用程序数据
最近两天我一直在做一些研究。
有人建议他们打开了许多连接,例如https://stackoverflow.com/a/13990490/1503155但我仍然无法弄清楚问题所在。
任何想法可能导致问题?
提前致谢。