- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我们遇到了一些奇怪的问题。它是这样的。我们有大量数据需要输出给客户端。这些数据文件不能预先构建,它们必须由实时数据提供。
我的首选解决方案是像这样从提取中逐行写入 CSV:
while($datum = $data->fetch(PDO::FETCH_ASSOC)) {
$size += fputcsv($outstream, $datum, chr(9), chr(0));
}
这解决了很多荒谬的内存使用问题(一次将 100000 条记录读入内存是一种糟糕的做法),但我们仍然存在大型表的挥之不去的问题,随着数据大小的增加,这些问题只会变得更糟。请注意,没有数据分区;他们不按年分段下载,但他们下载所有数据,然后自己分段。这是根据要求;我无法对此进行尽可能多的更改,因为它可以完全解决问题。
在任何一种情况下,它都会在最大的表上耗尽内存。一种解决方案是增加可用内存,这解决了一个问题,但如果有多个客户端正在下载,则建议稍后甚至现在创建服务器负载问题。
在这种情况下,$outstream 是:
$outstream = fopen("php://output",'w');
这看起来很明显不是真正的物理磁盘位置。我不太了解 php://output 就数据在发送到客户端之前所在的位置而言,但很明显,通过这种方法将流形数据库表简单地写入 csv 存在内存问题。
确切地说,暂存框允许 PHP 使用大约 128mb,而这个调用尤其短了大约 40mb(它试图再分配 40mb。)这看起来有点奇怪,因为您会期望它要求内存分成更小的部分。
有人知道如何处理这个问题吗?
最佳答案
所以看起来内存消耗是由 Zend Framework 的输出缓冲引起的。我想出的最佳解决方案是这个。
在我们开始将文件流式传输到客户端之前执行 ob_end_clean()。 ZF 的这个特定实例不会产生任何正常输出,也不会在此之后执行任何操作,因此不会出现复杂情况。奇怪的事情发生了(也许从用户的角度来看)是他们真的得到了流式传输给他们的文件。
代码如下:
ob_end_clean();
while($datum = $data->fetch(PDO::FETCH_ASSOC)) {
$size += fputcsv($outstream, $datum, chr(9), chr(0));
}
内存使用量(根据某处 ZF 论坛帖子中建议的函数 memory_get_peak_usage(true))从 90 兆字节下降到 9 兆字节,这是我的开发箱在读取任何文件之前使用的内存。
谢谢大家的帮助!
关于PHP 使用 fputcsv 到 php ://output 时减少内存使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11215129/
我正在用 C 语言实现一个带有输入和输出重定向的 shell。我可以成功进行输入重定向,但输出重定向不起作用。例如,如果我执行 ls > out.txt,则 out.txt 包含文本“out.txt”
我正在处理创建 AWS API 网关。我正在尝试创建 CloudWatch Log 组并将其命名 API-Gateway-Execution-Logs_${restApiId}/${stageName
我正在修改原作者使用数组构建网页的一些代码: $output[]=$stuff_from_database; $output[]='more stuff'; // etc echo join(
我只想知道它们之间的区别: sort < output 和 sort output 在 Linux 中。它是如何工作的? 最佳答案 这已经在 unix.stackexchange 上讨论过:Perfo
我正在生成外部控制台应用程序并使用异步输出重定向。 as shown in this SO post 我的问题是,在我收到 OutputDataReceived 事件通知之前,生成的进程似乎需要产生一
在 Udemy 上开设类(class)时,我们一直允许使用组件类中的 @Input() 装饰器向组件传递数据。 在阅读 ngBook-2 时,我发现还有另一种方法,即在 @Component 装饰器中
考虑一个 Linux 服务器,它在您的用户的 .bash_profile 中有以下行: echo "Hello world" 因此,每次您通过 ssh 进入它时,您都会看到 Hello world 现
public static void main(String[] args) { String input = new String(JOptionPane.showInputDialog("
我正在使用 MSVS 2008 中的 FFTW3 库对某些数据执行 r2c DFT (n=128)。我已经发现只使用了真实数据 DFT 输出的前半部分……如果我查看我的输出,这似乎是正确的: 0-64
我制作了一个 C 程序,可以从二进制文件中打印出很多值。我相信程序完成它的功能并在它实际显示它吐出的值之前结束。因此,结果我得到了一个可爱的 RUN SUCCESSFUL(总时间:198ms) 突然出
在 hadoop 作业计数器中,“映射输出具体化字节”与“映射输出字节”之间有什么区别?当我禁用映射输出压缩时我没有看到前者所以我猜它是真正的输出字节(压缩)而后者是未压缩的字节? 最佳答案 我认为你
有很多 Stack Overflow 文章与此相关,但没有直接的答案。 这条命令会输出一堆单词 OutputVariable.exe %FILEPATH% 输出: Mary had a little
互联网上的许多文章都使用“标准输入/输出/错误流”术语好像每个术语都与使用的“标准输入/输出/错误设备”术语具有相同的含义在其他文章上。例如,很多文章说标准输出流默认是监视器,但可以重定向到文件、打印
我在 Keras 中使用一些 tensorflow 函数(reduce_sum 和 l2_normalize)在最后一层构建模型时遇到了这个问题。我已经搜索了一个解决方案,但所有这些都与“Keras
我有来自 API 的自定义输出,我想将其格式化为带有一些颜色值的字符串。 最佳答案 输出 channel 可以用 TmLanguage grammar 着色. Output Colorizer扩展扩展
我正在寻找一种方法来查看虚拟机创建过程中发生的情况,因为我使用复杂的集群配置并测试其是否正常工作,我需要能够查看输出,在某些情况下我是不是因为敏感。这与运行remote-exec选项有关 module
当谷歌搜索此错误时没有看到任何相关结果,所以我想发布它。 stack build Building all executables for `gitchapter' once. After a suc
假设module_a里面有register_a,它需要链接到module_b。 register_a 是否应该单独声明并分配给 module_a 的输出: reg register_a; assign
我正在寻找一种方法来查看虚拟机创建过程中发生的情况,因为我使用复杂的集群配置并测试其是否正常工作,我需要能够查看输出,在某些情况下我是不是因为敏感。这与运行remote-exec选项有关 module
输入文件如下 eno::ename::dept::sal 101::emp1::comp1::2800000 201::emp2::comp2::2800000 301::emp3::comp3::3
我是一名优秀的程序员,十分优秀!