【问题标题】:Codeigniter - Blank screen when trying to retrieve 8500 recordsCodeigniter - 尝试检索 8500 条记录时出现空白屏幕
【发布时间】:2011-03-23 03:48:16
【问题描述】:

我正在尝试显示一个包含 8500 条记录的表格,我使用的控制器/模型功能与我在整个站点中使用的相同,它们都可以正常工作。

然而,在这个页面上,我只看到一个空白屏幕。这是 codeigniter 的已知问题吗?有解决办法吗?我完全被难住了,我想我唯一的选择是将表拆分为子表?

如果需要,我可以向您展示我的代码。

谢谢

【问题讨论】:

  • 请向我们展示代码:) 行数肯定很小,应该不是问题。另外,检查错误日志。

标签: php mysql database activerecord codeigniter


【解决方案1】:

当你得到一个空白屏幕时,通常意味着你已经做了一些事情来接收一个 PHP 错误。

要查看该错误是什么,请查看 php 错误日志。我怀疑您已超出允许的最大内存限制。

php_value memory_limit 256M
php_value display_errors 1
php_flag log_errors on
php_value error_log /some/path/on/the/box/you/have/acess/to.log

下面是启用设置的硬编码 PHP 方法,在这一行上方是您可以设置的 .htaccess 指令,这些指令将用于您的整个应用程序。

为了确保错误报告已打开并且您正在显示错误,您可以这样做..

ini_set('display_errors', 'On');
error_reporting(E_ALL);

要找出您的错误日志在哪里,请制作一个测试脚本来告诉您。

die(ini_get('error_log'));

确保在您的 php.ini 文件中也启用了 log_errors ini 设置。

如果你确实超过了最大允许内存限制,你可以通过这样做来增加它

ini_set(“memory_limit”,”256M”); // 256 megabytes

我建议在您的 php.ini 文件中更新它并重新启动 apache 以使更改生效。

如果您的脚本正在处理大量数据并且可能需要一段时间才能运行,那么您也可能会超出 max_execution_time ini 设置。

要查看当前设置的位置,您可以这样做

die(ini_get('max_execution_time'));

有一个不错的 PHP 助手功能可以为您设置这个set_time_limit

set_time_limit(300); // Input in seconds, this is 5 minutes.

希望这可以帮助您到达某个地方。 不过,最好的办法是查看错误日志。

祝你好运。

【讨论】:

  • 感谢保罗的意见。该应用程序位于共享服务器上,因此我无法直接访问 php.ini 除了这些指令,哪里是最好的地方?在我的控制器或视图文件中?例如ini_set("memory_limit","256M"); // 256 兆字节
  • Dan,然后将它们放入 .htaccess 文件中。 htaccess 覆盖同一目录和所有子目录中的所有文件的 php.ini。我已经用您可以指定的更多 .htaccess 指令更新了帖子
  • 再次感谢保罗,已经到了!一次它会加载正常,然后在接下来的 5 次我得到空白屏幕 - 奇怪!这对你有什么建议吗?
  • 每次出现空白屏幕时,按照我上面的建议检查错误日志
  • hmmm,那里没有错误消息,只是调试消息详细说明了哪些库等正在加载,还有一条消息说模板和视图文件已加载。
猜你喜欢
  • 2011-12-06
  • 2011-03-15
  • 1970-01-01
  • 2013-12-25
  • 2015-06-21
  • 2014-04-19
  • 2018-11-29
  • 2020-06-23
  • 1970-01-01
相关资源
最近更新 更多