- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们试图在Firefox 28上使用html5和indexeddb构建基于客户端的应用程序。AJAX请求使用json格式首次将大量数据加载到firefox中。每个json资源大约2MB(压缩),数据将通过IDBWrapper存储到indexeddb。
Firefox的内存使用量随着响应迅速增加。当我们运行大约12个响应时,firefox的内存将增长到大约1GB(总计3GB),有时会导致AJAX错误。成功加载后,内存将直接降至500MB或以下。
似乎在整个加载/存储过程中,firefox都没有机会进行GC,我们尝试在每个响应之间使用setTimeout,但这似乎是无奈的。
我的问题是,在加载大json时,还有其他方法可以减少firefox的内存使用吗?
编辑:
代码是这样的:
$.ajax({
url : URL['getData'],
dataType : "json",
data : {
startDate : _startDate,
endDate : _endDate,
format : "json"
},
async : true,
success : function(_data) {
_data = null;
// store to indexeddb
_callback();
},
error : function() {
setCurrentDataLabel('Error', 0);
}
});
dataType : "json"
更改为
dataType : "text"
,则内存使用量很小,GC显然正在运行。似乎Firefox在处理json时存在一些性能问题。
最佳答案
服务器端分页
如果所讨论的“服务器”正在运行某种编程语言/框架,并且如果您可以轻松地更改在该服务器上运行的代码,则最简单的方法就是@Coder
在注释中所指。即:服务器端分页。
我将离开@Coder
为“服务器分页”情况提供答案。
客户端流
另一方面,如果没有代码可以在服务器上进行更改(例如:它是由其他进程生成的静态JSON文件,并且只有一个简单的静态HTTP服务器),那么您可能想要采用我在评论中提到,即:让客户端进行流式传输。
在这种方法中:
您向服务器请求整个JSON文件(无论是2MB或更大),而不是使用XMLHttpRequest
(AJAX),而是使用Firefox(StreamListener
)中的本机平台API。
随着数据变得可从服务器读取,您可以使用所谓的JSON“ Pull Parser”来解析JSON到达的文本。
您解释拉取解析器发出的解析“事件”流,以便将数据增量写入本地存储(无论是数据库还是文件)。
注意1:
您不能在服务器端(显式或自动)使用GZIP编码,而仍然在客户端上进行流读取。您要么必须将服务器显式配置为仅提供未压缩的JSON,要么可以简单地使用Accept-Encoding:
标头要求服务器不要向您发送压缩的内容(询问不存在的压缩方案,例如
笔记2:
您还不能通过“内容” JavaScript(即:网络服务器提供的JavaScript内容)执行这种HTTP请求。您只能通过“特权” JavaScript(例如,在Firefox插件中)执行此操作。
沙盒HTTP请求
我不会提供发出请求本身的示例(它很大),但是您基本上可以从MDN的
Creating Sandboxed HTTP Connections页剪切并粘贴第一个(最简单的)示例。
在示例中,在
dont-compress-please
回调中,它们只是将读取的文本添加到缓冲区(字符串)中,如下所示:
this.mData += scriptableInputStream.read(aLength);
onDataAvailable
);而是在收到的源文本的每个块上调用其
JSON.parse
方法。解析器负责弄清楚它在输入流中的位置(使用“状态机”),以及何时开始或结束读取所谓的“ atom”(对于JSON,例如:
tokenize()
,< cc>,
Array
的结尾,
Number
的开头等),它将调用您提供的回调(或发出事件)来告知您。
Array
的
Object
。基本上,您应该忽略“
Array
的开始”,然后对于每个“
Object
的结束”,将单个
Array
中的数据写入您的语言环境存储。这样一来,您一次存储在内存中的最大事情就是较大文件中的单个行/元素。
Object
界面具有特权,因此,如果您仍然希望此Web应用程序主要在Web上运行(并且仅具有脱机模式),则需要在Firefox插件中实现它。
Object
回调调用了Pull Parser,因此也需要在附加组件内部将其实现为特权JavaScript。
关于javascript - 在将大型json加载到firefox时占用大量内存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23321384/
我正在阅读 SQL/92(我是新手),它经历了不同的数据类型。其中之一是CHAR,我当然知道它与java中的String非常相似,而不是java中的char。但我们假设它是 CHAR(1)。只有一个字
我的 mysqld 进程消耗了 232% 的 CPU,并且有 14000 多个连接 (我对这件事有点陌生,但关注 Stack Overflow 寻求帮助)。 顶部: PID USER P
Tomcat 服务器占用 100% 的 CPU,但仅在 PRD。我们无法在其他环境中重现这一点。 进行线程转储后,我们发现有一些线程处于等待/可运行状态,但无法找到我们如何找到根本原因。 你能帮忙吗?
我正在使用 Xcode、SpriteKit 和 Swift 构建我的第一款 iPhone 游戏。我对这些技术不熟悉,但我熟悉一般的编程概念。 这是我想用英语做的事情。我想让圆圈随机出现在屏幕上,然后开
我的套接字消耗了 100% 的计算机 CPU。有 150 个客户端每 30 秒异步向服务器发送消息。有谁知道如何解决这个问题?下面是我的 ServerSocket 类 public class Ser
一段时间后(有时几分钟,有时几天),我的应用开始消耗 100% 的 CPU。正如我从 VisualVM 看到的那样,它总是发生在 org.elasticsearch.common.netty.chan
在我的容器 Controller 中,用户可以平移 View 以切换到不同的 View 。当平移手势开始时,它会将新 View Controller 的 View 添加到 View 中:view.in
假设我在数据框中有两列,其中一列不完整。 df = pd.DataFrame({'a': [1, 2, 3, 4], 'b':[5, '', 6, '']}) df Out: a b
在Ubuntu 16.04 LTS中,pyteserract脚本吃得太高,导致系统间歇性重启。 top命令输出为 top - 21:23:31 up 27 min, 4 users, lo
我在具有 88 个内核和 60 个 reducer 的 hadoop 集群上运行 mapreduce 作业。由于某种原因,它只使用了 79 个集群核心。开始时它运行 79 个映射器,但当完成一半拆分时
我正在对机器上的所有用户进行查询,当它执行时,它会占用 100% 的 CPU 并锁定系统。我已经等了 5 分钟,但什么也没有发生。 在任务管理器中,wmiprvse.exe 占用了所有 CPU。当我终
我正在从套接字(通过 TCP 协议(protocol))读取消息,但我注意到 CPU 花费大量时间来调用 BufferedInputStream 的 available() 方法。这是我的代码:
我有 6 个线程。其中一个线程进入某个范围并打开“锁定”和所有其他线程线程正在等待并希望进入相同的范围。 现在,其他线程是否会获得 CPU 时间?其他线程是否在线程调度中?我知道所有其他线程都处于等待
我正在尝试创建一个社交媒体应用程序。但它需要大约 300mb 内存。所以我的主页上有 5 个包含帖子的 fragment 。总体内存使用量为 250-300mb 然后为了测试,我禁用了这些 fragm
我有一个带有一些 TextFormField 的表单,我想扩展最后一个 TextFormField 以占据屏幕的其余部分。最后一个 TextFormField 可以有多行文本。 我没能做到这一点,并尝
我收到磁盘几乎已满的警告,所以我运行 DaisyDisk .. 显然 Xcode 占用了 15GB 的空间: http://imgur.com/a/cTIZZ iOS 设备支持为 12.3 GB: h
我正在使用 Xcode Playground 研究 Swift 内存布局,我创建了一个带有 bool、double 和 int32 的结构,如下所示。基于这种结构,MemoryLayout 的打印结果
一旦执行“self.navigationController pushviewcontroller:vc animated:YES”,我的 CPU 就会达到 100%。我在 Stack Overflo
警告:CPU 使用率达到 100%,请小心。 Link to the jsFiddle 编写此脚本是为了设计动态蛇梯板。每次刷新页面时,都会创建一个新板。大多数时候所有的背景图像都不会出现,CPU 使
我不知道为什么,但是MYSQL给CPU带来了很大的负载。我必须每秒多次更新数据库,并且用户群正在不断增长。 一开始还好,但是现在 CPU 负载每天都在增加 这是日志中的慢速查询: *Query_tim
我是一名优秀的程序员,十分优秀!