如何解决SBOX_FATAL_MEMORY_EXCEEDED 分块上传文件时
我有这个(简化的)代码来上传一个文件块:
let reader = new FileReader();
let blob = file.slice(0,STEP);
reader.readAsDataURL(blob);
reader.onload = (e) =>
{
let d =
{
container: container,blob: BlobName,file: reader.result,id: id
};
$.ajax({
url: uploadPath,type: "POST",data: d,timeout: 30000
}).done(function(r)
{
if (r.success == "yes")
{
Loaded += e.loaded;
if(Loaded < total)
{
blob = file.slice(Loaded,Loaded + STEP); // getting next chunk
reader.readAsDataURL(blob); // trigger onload for next chunk
}
else
{
// File is completely uploaded
}
}
else
{
if (tries++ > 3)
{
// error management here
}
else
{
// try again
reader.readAsDataURL(blob); // trigger again onload
}
}
}).fail(function (jqXHR,textStatus,errorThrown)
{
if (tries++ > 3)
{
// error management here
}
else
{
// try again
reader.readAsDataURL(blob); // trigger again onload
}
}
}
即使对于大文件 (43 GB),此代码也能发挥作用。
今天,我们不得不上传一个大文件 (20 GB),我们在 Chrome (88) 上得到了一个 SBOX_FATAL_MEMORY_EXCEEDED
经过大量测试和监控后,我们注意到在使用此上传时,Chrome 中的内存使用量越来越大。
进行了其他测试,我们注意到 Edge 和 Firefox 上的行为相同(上传可以在 FF 上完成,但仍使用 GB 的 RAM)
我该怎么做才能解决这种糟糕的内存管理问题?
解决方法
事件的递归触发器似乎阻止了块立即被 GC
块的引用可以设置为 null
以使其符合 GC 的条件:
在每个 readAsDataURL()
之前,添加:
reader.result = null; // the result itself
d.file = null; // the chunk in the current object sent to the server
reader.readAsDataURL(blob);
现在可以通过正确的内存管理正常工作,在上传过程中保持稳定
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。