我正在运行一个wordpress站点,每个PHP进程使用大约200mb到250mb的驻留大小内存。凭借16GB的ram,服务器只能处理大约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`
答案 0 :(得分:7)
我将总结Lisa为解决问题所做的工作:
pmap -d <pid>
检查单个PHP进程的内存布局。输出显示该进程使用了大量共享内存: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
在cut -d'' - f2 | grep'^ [0-9]'`;做ipcrm -m $ i;完成
答案 1 :(得分:3)
Rasmus Lerdorf在2010年的Confoo上做了一个关于PHP性能的会议,他以Wordpress博客为例,这应该会为你提供很好的工具来回答你的问题:
http://talks.php.net/show/confoo10/1
总结一下:
phpinfo()
并禁用不使用的PHP扩展。他们可以留下很多记忆(想象力,卷曲......)siege
运行基准测试。有时,微小的优化会对性能产生很大影响,因此请确保您有指标,以帮助您做出决策。md5()
来散列我的SQL查询并缓存它们。 md5()
调用使用20%CPU时间的地方。如果可能的话,我肯定会从禁用PHP扩展开始。