php – 拥有100个用户的Symfony2网站= 100%的CPU费用

前端之家收集整理的这篇文章主要介绍了php – 拥有100个用户的Symfony2网站= 100%的CPU费用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一个问题,我无法用我的服务器解决.我可能会错过某处的配置,但我搜索并发现没什么好的.

服务器硬件:
英特尔凌动N2800
2芯,4芯(http://ark.intel.com/products/58917/)
4Gb RAM

它使用Nginx,PHP5 FPM和MysqL在Debian7下运行.

只有一个网站在运行.同时平均50位访客,最多可达140位访客.

这是高峰时间发生的事情:

  1. top - 23:01:41 up 80 days,8:40,1 user,load average: 19,78,19,52,37
  2. Tasks: 166 total,22 running,144 sleeping,0 stopped,0 zombie
  3. %cpu(s): 90,6 us,9,1 sy,0 ni,0 id,0 wa,0 hi,3 si,0 st
  4. KiB Mem: 4020300 total,3232164 used,788136 free,362764 buffers
  5. KiB Swap: 525308 total,121404 used,403904 free,1191508 cached
  6. PID USER PR NI VIRT RES SHR S %cpu %MEM TIME+ COMMAND
  7. 32295 www-data 20 0 247m 37m 6456 R 19,5 1,0 4:02.15 PHP5-fpm
  8. 32469 www-data 20 0 251m 40m 6592 R 19,0 3:30.46 PHP5-fpm
  9. 32689 www-data 20 0 243m 32m 6816 R 19,2 0,8 2:56.03 PHP5-fpm
  10. 32692 www-data 20 0 251m 41m 6564 R 19,2 1,0 2:57.84 PHP5-fpm
  11. 1115 www-data 20 0 251m 40m 6428 R 18,9 1,0 0:54.01 PHP5-fpm
  12. 1249 www-data 20 0 251m 40m 6356 R 18,0 0:42.35 PHP5-fpm
  13. 1251 www-data 20 0 250m 39m 6420 R 18,0 0:37.36 PHP5-fpm
  14. 31314 www-data 20 0 251m 40m 6440 R 18,0 6:52.49 PHP5-fpm
  15. 32296 www-data 20 0 251m 40m 6560 R 18,0 4:03.63 PHP5-fpm
  16. 32410 www-data 20 0 251m 40m 6708 R 18,0 3:53.65 PHP5-fpm
  17. 32468 www-data 20 0 247m 36m 6720 R 18,9 0,9 3:27.14 PHP5-fpm
  18. 32471 www-data 20 0 251m 40m 6472 R 18,0 3:33.24 PHP5-fpm
  19. 32691 www-data 20 0 251m 40m 6584 R 18,0 3:03.90 PHP5-fpm
  20. 32294 www-data 20 0 251m 40m 6452 R 18,0 4:18.55 PHP5-fpm
  21. 32297 www-data 20 0 251m 40m 6456 R 18,0 4:07.43 PHP5-fpm
  22. 32467 www-data 20 0 246m 35m 6456 R 18,5 0,9 3:41.64 PHP5-fpm
  23. 1250 www-data 20 0 241m 30m 6312 R 18,8 0:37.06 PHP5-fpm
  24. 32114 www-data 20 0 247m 37m 6428 R 18,9 4:38.27 PHP5-fpm
  25. 32470 www-data 20 0 243m 32m 6424 R 18,8 3:30.56 PHP5-fpm
  26. 32527 www-data 20 0 239m 28m 6428 R 18,7 3:19.96 PHP5-fpm
  27. 1629 root 20 0 17228 5444 1308 S 2,1 0:01.63 rkhunter
  28. 23561 MysqL 20 0 488m 73m 7944 S 1,3 1,9 227:34.60 MysqLd
  29. 4016 root 20 0 23740 1660 1136 R 0,7 0,0 0:00.07 top
  30. 20368 www-data 20 0 66340 4732 2116 S 0,3 0,1 10:34.08 Nginx

你肯定明白我不能这样.

该网站使用Symfony2构建.
symfony的配置文件可在此处获取http://pastebin.com/CJbea0Qf

PHPinfo在那里:https://drive.google.com/file/d/0ByNmwlJzaeKpNkNTcF9GZGNQVmM/edit?usp=sharing

这是网站的Nginx配置(我找到了一个例子并稍微修改了一下)
重写规则是因为旧地址.

  1. server {
  2. listen *:80;
  3. server_name ***.fr www.***.fr;
  4. root /home/www/clients/client1/web7/web/beta/web/;
  5. rewrite ^/index.PHP / permanent;
  6. rewrite ^/disclaimer.PHP / permanent;
  7. rewrite ^/disclaimer-mobile.PHP / permanent;
  8. rewrite ^/news.PHP /news permanent;
  9. rewrite ^/contact.PHP /contact permanent;
  10. rewrite ^/app\.PHP/?(.*)$/$1 permanent;
  11. try_files $uri @rewriteapp;
  12. location @rewriteapp {
  13. rewrite ^(.*)$/app.PHP/$1 last;
  14. }
  15. # Deny all . files
  16. location ~ /\. {
  17. deny all;
  18. }
  19. # Do some static file caching
  20. location ~* \.(jpg|jpeg|gif|png|css|js|ico|xml)${
  21. log_not_found off;
  22. expires 1d;
  23. }
  24. location ~ ^/(app|app_dev)\.PHP(/|$) {
  25. fastcgi_split_path_info ^(.+\.PHP)(/.*)$;
  26. include fastcgi_params;
  27. fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  28. fastcgi_index app.PHP;
  29. send_timeout 1800;
  30. fastcgi_read_timeout 1800;
  31. fastcgi_buffer_size 128k;
  32. fastcgi_buffers 256 16k;
  33. fastcgi_busy_buffers_size 256k;
  34. fastcgi_pass unix:/var/run/PHP5-fpm.sock;
  35. #fastcgi_pass 127.0.0.1:9000;
  36. }
  37. location ~ ^/(mystatus|myping)${
  38. access_log off;
  39. include fastcgi_params;
  40. fastcgi_pass unix:/var/run/PHP5-fpm.sock;
  41. }
  42. # Statics
  43. location /(bundles|media) {
  44. access_log off;
  45. expires 30d;
  46. # Font files
  47. #if ($filename ~* ^.*?\.(eot)|(ttf)|(woff)$){
  48. # add_header Access-Control-Allow-Origin *;
  49. #}
  50. try_files $uri @rewriteapp;
  51. }
  52. }

最后,PHP-FPM配置.

  1. pm = dynamic
  2. pm.max_children = 20
  3. pm.start_servers = 10
  4. pm.min_spare_servers = 8
  5. pm.max_spare_servers = 15
  6. pm.max_requests = 400

我不知道你是否需要其他数据来帮助我解决这个问题.

该网站非常“轻松”.没有很多用户交互,只是简单的页面(它主要是一个图库),所以只是页面生成.

非常感谢

一件可能(或不是)重要的事情
当我重新加载PHP5-fpm时,负载电量相当平静(~2),但随着时间的推移放大,直到不低于8.

演化
我用Nginx fastcgi_cache参数设置了一个缓存.每个页面缓存5分钟.这将打破所有“视图”计数器,但我不在乎网站显然更快.
我注意到,现在,当我执行PHP5-fpm重新加载服务时,服务器将降至1负责!即使有100名访客同时也是如此.但奇怪的是,昨天一次,它开始再次上升,20次充电.我确实重装了PHP5-fpm,这一切都降到了1!它从昨天起就开始工作了.
似乎有某种触发点让PHP-fpm变得疯狂!

最佳答案
使用新设置一周后,我将采取以下措施来改善服务器的性能.

首先,我使用了Nginx fastcgi缓存.这显然提高了性能!!缓存的页面非常快.
我遵循http://www.digitalocean.com/community/articles/how-to-setup-fastcgi-caching-with-nginx-on-your-vpshttp://techminded.net/blog/transparent-cache-in-nginx.html这样的东西很容易理解它是如何工作的.我的缓存设置为5分钟.对于某些页面来说太多了,对其他页面来说还不够.我必须在这一点上努力.但由于这是PHP-FPM占用所有资源,而不是执行PHP代码显然降低了cpu费用.

其次,我将APC缓存大小设置为128M我认为这是我的服务器配置的最大问题. Symfony使用APC很多,APC缓存是100%碎片!我在apc stat页面看到了这个(从这里得到它,因为它在我的服务器上没有出现:http://jesin.tk/apc-php-download/).现在,APC缓存碎片为0.76%,95%已满,100%缓存命中!
我更改的设置:apc.shm_size 128M和apc.max_file_size 3M.

顺便说一下,在APC统计页面上,我可以看到1728.50缓存请求/秒.当然,如果你的缓存不好,性能会很差.现在一切都清楚了!这应该在Symfony的文档中解释,因为它是非常重要的一点.

服务器现在非常稳定,cpu负载大约2.我想我解决了!

猜你在找的Nginx相关文章