ZipOutputStream 内存泄漏

发布于 2024-12-18 19:09:18 字数 1554 浏览 3 评论 0原文

我正在使用 ZipOutputStream 从数据库获取文件,压缩为 zip 并下载(zip 文件大约 400mb)。 在此期间,我的应用程序池内存将上升到 1.4gb,下载完成后,它会下降到 1gb,而此时它应该会恢复到 100 mb 左右 或者其他什么。 只有 10 位用户使用此应用程序,只有 1 位用户使用此特定页面。 我正在调用 dispose 方法。我也尝试显式调用 GC.Collect 但仍然没有用。 我在这里错过了什么吗?

提前致谢。

  Dim zipStream = New ZipOutputStream(HttpContext.Current.Response.OutputStream)
    Try


        da.Fill(ds)
        For Each dr As DataRow In ds.Tables(0).Rows
            Try
                Dim docName As String = ""
                strImgID = dr("image_id")
                If Not IsDBNull(dr("loan_number")) Then iLoanID = dr("loan_number")

                If Not IsDBNull(dr("document_name")) Then docName = dr("document_name")
                Dim ext As String = dr("image_type_extension")
                Dim strFinalFileName As String = ""

                strFinalFileName = docName & "_" & iLoanID & ext

                Dim b As Byte() = dr("image_binary")
                Dim fileEntry = New ZipEntry(Path.GetFileName(strFinalFileName))
                zipStream.PutNextEntry(fileEntry)
                zipStream.Write(b, 0, b.Length)
            Catch ex As Exception
                LogError(ex, iLoanID & "," & strImgID)
                AddError(sb, ex, iLoanID & "," & strImgID)
            End Try
        Next

     Catch ex As Exception
        Throw
    Finally

        zipStream.Close()
        zipStream.Dispose()
          cmd.Connection.Close()
        cmd.Connection.Dispose()
    End Try

I am using ZipOutputStream to get files from db, compress to zip and download (zip file around 400mb).
During this, my app pool memory is going up to 1.4gb and after download is complete, its coming down to 1gb when it should come back to like 100 mb or something.
There are only like 10 users using this app and only 1 user using this particular page.
i am calling the dispose method. I aslo tried explictly calling GC.Collect but still no use.
Am i missing anything here?

Thanks in advance.

  Dim zipStream = New ZipOutputStream(HttpContext.Current.Response.OutputStream)
    Try


        da.Fill(ds)
        For Each dr As DataRow In ds.Tables(0).Rows
            Try
                Dim docName As String = ""
                strImgID = dr("image_id")
                If Not IsDBNull(dr("loan_number")) Then iLoanID = dr("loan_number")

                If Not IsDBNull(dr("document_name")) Then docName = dr("document_name")
                Dim ext As String = dr("image_type_extension")
                Dim strFinalFileName As String = ""

                strFinalFileName = docName & "_" & iLoanID & ext

                Dim b As Byte() = dr("image_binary")
                Dim fileEntry = New ZipEntry(Path.GetFileName(strFinalFileName))
                zipStream.PutNextEntry(fileEntry)
                zipStream.Write(b, 0, b.Length)
            Catch ex As Exception
                LogError(ex, iLoanID & "," & strImgID)
                AddError(sb, ex, iLoanID & "," & strImgID)
            End Try
        Next

     Catch ex As Exception
        Throw
    Finally

        zipStream.Close()
        zipStream.Dispose()
          cmd.Connection.Close()
        cmd.Connection.Dispose()
    End Try

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

許願樹丅啲祈禱 2024-12-25 19:09:18

您需要将数据分块到流中,而不是一次性分配所有数据。

例如(在 c# 中)

byte[] buffer = new byte[4096];

FileStream readFs = File.OpenRead(strFile);

for (int rnt = readFs.Read(buffer, 0, buffer.Length); 
      rnt > 0; 
      rnt = readFs.Read(buffer,  0, buffer.Length))
{
      zipoutputstream.Write(buffer, 0, rnt);
}

我认为这将有助于解决您的内存问题。如果没有请评论回来..

You need to chunk data into the stream rather than allocate all at once.

E.g. (in c#)

byte[] buffer = new byte[4096];

FileStream readFs = File.OpenRead(strFile);

for (int rnt = readFs.Read(buffer, 0, buffer.Length); 
      rnt > 0; 
      rnt = readFs.Read(buffer,  0, buffer.Length))
{
      zipoutputstream.Write(buffer, 0, rnt);
}

I think this will help with your memory issue. Please comment back if not..

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文