10

我正在运行一个 wordpress 站点,每个 PHP 进程使用大约 200mb 到 250mb 的常驻大小内存。使用 16GB 的内存,服务器只能处理大约 70 个进程。通过将虚拟内存增加到 16GB,它可以处理 140 个。之后负载不断上升。如果在 10 分钟内有 200 个连接,则服务器负载在 3Ghz 四核至强处理器上达到 20!

我已经尝试停用所有插件,但这只会将每个进程的 PHP 内存使用量减少不到 10%。suPHP 告诉我哪个用户使用了这么多内存,但不告诉我 wordpress 代码的哪一部分。

关于如何减少内存使用的任何建议?还是我升级到 32GB 内存的唯一选择?

PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
10585 nobody    16   0 2266m 237m 199m S 21.3  1.5   1:09.17 /usr/bin/php
10597 nobody    16   0 2257m 255m 226m S 15.3  1.6   0:17.56 /usr/bin/php

pmap -d 的最大输出

000000000e8b8000   27580 rw--- 000000000e8b8000 000:00000   [ anon ]
00002b3772850000 2097152 rw-s- 0000000000000000 000:00009   [ shmid=0x2d1b803a ]
00002b37f2a62000   55108 r---- 0000000000000000 0fd:00000 locale-archive
mapped: 2320852K    writeable/private: 30012K    shared: 2097152K

ipcs 输出

------ Semaphore Arrays --------

key        semid      owner      perms      nsems
0x000000a7 0          root      600        1
0x00000000 162529281  nobody    600        1
0x00000000 162562050  nobody    600        1
0x00000000 162594819  nobody    600        1
0x00000000 162627588  nobody    600        1
------ Message Queues --------

key        msqid      owner      perms      used-bytes   messages`
4

2 回答 2

7

我将总结 Lisa 为找到问题所做的工作:

  • 使用 .检查单个 PHP 进程的内存布局pmap -d <pid>。输出显示该进程使用了​​大量共享内存:
00002b3772850000 2097152 rw-s- 0000000000000000 000:00009   [ shmid=0x2d1b803a ]
  • 用 . 检查共享内存区域ipcs -m。它表明有很多由用户nobody(Web服务器)创建的共享内存区域,这里只是其中的一部分:
0x00000000 117964807 nobody 600 2147483648 1 dest 
0x00000000 117997576 nobody 600 2147483648 1 dest 
0x00000000 118030345 nobody 600 2147483648 1 dest
0x00000000 118063114 nobody 600 2147483648 1 dest
  • 在 php.ini 中禁用 eAccelerator 并删除创建的共享内存区域:

对于 i 在 `ipcs -m | 剪切-d''-f2 | grep '^[0-9]'`; 做 ipcrm -m $i; 完毕

于 2012-04-27T21:21:09.277 回答
3

Rasmus Lerdorf 于 2010 年在 Confoo 举办了一次关于 PHP 性能的会议,他以 Wordpress 博客为例,这应该为您提供很好的工具来回答您的问题:

http://talks.php.net/show/confoo10/1

总结一下:

  • 运行phpinfo()并禁用您不使用的 PHP 扩展。它们会占用大量内存(imagick、curl、...)
  • 使用 included.so 扩展生成包含的图表。您可能会在您的 wordpress 设置中加载无用的功能。
  • 运行基准测试siege。有时,微小的优化会对性能产生很大影响,因此请确保您有指标,以帮助您做出决定。
  • 使用 callgrind 显示性能下降的地方。在我的一个项目中,我md5()用来散列我的 SQL 查询并缓存它们。使用 20% 的 CPU 时间的md5()调用。

如果可能的话,我肯定会从禁用 PHP 扩展开始。

于 2012-04-27T20:06:11.137 回答