我有以下操作,每 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但我仍然无法弄清楚问题所在。
任何想法可能导致问题?
提前致谢。