- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我刚刚继承了一个带有 PHP 脚本的站点,该脚本一直在 117 MB 内存不足。即使我通过 php.ini 将 PHP 的 memory_limit 变量增加到 312 MB,也会发生这种情况。
感谢 pcguru 提供的一个很好的线索,现在这个问题已经解决了。请参阅下面开始的我的答案:我终于找到了答案
ini_get('memory_limit')
返回 php.ini 中设置的值,所以我确定 Apache 在更改值后已经重新启动。我正在使用 memory_get_usage(true)
来返回脚本在沿途各个点消耗的内存。当它达到 117 MB 时,它总是失败。
是否存在一些我不知道的内部 PHP 限制,它从未为单个脚本分配超过 117MB 的空间?
服务器有 1GB 的 RAM 并且正在运行 CentOS。我有 root shell 访问权限。 PHP 版本为 5.3.18。 MySQL 版本为 5.1.66-cll。
此脚本位于用户名/密码后面,我无法提供对其的公共(public)访问权限。
编辑添加:
1) 感谢大家迄今为止的帮助。您可以在下面各种答案下我对特定用户评论的回复中找到更多信息。
2) Suhosin 肯定没有安装。我检查了多个地方,包括运行脚本并检查常量和运行 php -v
3) apache 日志没有记录我收到的具体错误消息。日志在 php.ini 中打开。我通过 grep 管道搜索整个日志。
4) 这种情况下会不会报错?
最佳答案
我终于找到了答案。线索来自 pcguru 的回答,开头是“因为服务器只有 1 GB 的 RAM...”。
凭直觉,我查看了 Apache 是否有自己的内存限制,因为这些限制可能会影响 PHP 分配内存的能力。在 httpd.conf 的顶部,我发现了以下语句:RLimitMEM 204535125
这是由 whm/cpanel 放在那里的。根据以下网页 whm/cpanel 在虚拟服务器上错误地计算其值... http://forums.jaguarpc.com/vps-dedicated/17341-apache-memory-limit-rlimitmem.html
内存不足的脚本大部分都通过了,所以我将 RLimitMEM 增加到 268435456 (256 MB) 并重新运行脚本。它完成了数组合并并生成了 csv 文件以供下载。
ETA:在进一步阅读了 RLimitMEM 和 RLimitCPU 之后,我决定将它们从 httpd.conf 中删除。这允许 ini_set('memory_limit','###M') 工作,我现在给那个特定的脚本它需要的额外内存。我还将该服务器上的 RAM 增加了一倍。
感谢大家帮助发现这个相当棘手的问题,特别感谢 pcguru 提出了让我找到解决方案的重要线索。
关于memory - 即使未达到 memory_limit,PHP 也会出现内存不足错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13955914/
所以我正在为考试复习,并在 SQL 河(或荒地)中撞到了一块大石头 我制作了以下表格并插入了以下数据: create table Permissions ( fileName VARCHAR(
我有一个使用 maxWidth 定义的 jqueryui 对话框。 $("#myDialog").dialog({ autoOpen: false, width: 'a
注意:我遗漏了不相关的代码 所以我目前正在研究 CCC 1996 P1,这个问题的全部目的是能够计算一个整数输入是完美数、不足数还是充数。我上面列出的代码可以工作,但是我认为它太慢了。该代码会迭代每个
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我正在使用 Go 和 Redis 开发 API。问题是RAM使用不足,我找不到问题的根源。 TL;DR 版本 有数百/数千个哈希对象。每个 1 KB 的对象(键+值)占用大约 0.5 MB 的 RAM
在我的 GCE Kubernetes 集群上,我无法再创建 pod。 Warning FailedScheduling pod (www.caveconditions.com-f1be467e3
当我尝试在EKS Fargate群集上安装指标服务器时,它抛出错误: 0/4 nodes are available: 4 Insufficient pods. 按照以下说明从此处安装指标服务器:ht
遍布this document Apple 提到 iOS 在某些情况下会终止应用程序,最常见的原因似乎是释放一些 RAM。这会导致未实现状态恢复的应用程序出现问题——用户正在处理和暂时离开的一些内容可
尝试处理一个10分钟的音频文件时出现以下错误。我刚刚开始使用Google Cloud产品,所以我是唯一访问此资源的人。我怎么可能超出配额?配额设置为其默认值,我认为我没有任何限制。还有其他原因吗? 我
R 语言让我感到困惑。实体有模式和类,但即使这样也不足以完全描述实体。 这个answer说 In R every 'object' has a mode and a class. 所以我做了这些实验:
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
我在 west-1 有一个 Openshift v3 项目。在其中,我有一个运行良好的应用程序,但在 GitHub 提交代码中非常下游的内容后,该应用程序停止工作。问题在于制作 pod: No nod
在 how-do-i-access-the-stackoverflow-api-from-mathematica我概述了如何使用 SO API 让 Mathematica 制作一些有趣的顶级回答者声誉
所以在 GKE 上,我有一个 Node.js app,每个 pod 使用大约:CPU(cores): 5m, MEMORY: 100Mi 但是我只能为每个 Node 部署 1 个 pod。我使用的是
我正在使用 async.eachOfSeries 超过 300 个数组并请求一些 GA api,它工作正常但有时我会收到错误.. UnhandledPromiseRejectionWarning:错误
我正在尝试在 AWS ec2 上托管的 kubernetes 集群上使用 mr3 设置配置单元。当我运行命令 run-hive.sh 时,Hive 服务器启动,并且 master-DAg 被初始化,但
创建订阅时有时会出现以下错误: Insufficient tokens for quota 'administrator' and limit 'CLIENT_PROJECT-100s' of ser
我是一名优秀的程序员,十分优秀!