gpt4 book ai didi

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

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:38:41 26 4
gpt4 key购买 nike

我有一个无法用我的服务器解决的问题。我可能在某处遗漏了一个配置,但我进行了搜索并没有找到任何合适的东西。

服务器硬件:英特尔凌动 N28002 核,4 线程 ( http://ark.intel.com/products/58917/ )4Gb 内存

它在 Debian7 下运行,带有 NGinx、PHP5 FPM 和 MySQL。

只有一个网站在运行。平均同时接待 50 位访客,最高可达 140 位访客。

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

top - 23:01:41 up 80 days,  8:40,  1 user,  load average: 19,78, 19,52, 19,37
Tasks: 166 total, 22 running, 144 sleeping, 0 stopped, 0 zombie
%Cpu(s): 90,6 us, 9,1 sy, 0,0 ni, 0,0 id, 0,0 wa, 0,0 hi, 0,3 si, 0,0 st
KiB Mem: 4020300 total, 3232164 used, 788136 free, 362764 buffers
KiB Swap: 525308 total, 121404 used, 403904 free, 1191508 cached

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
32295 www-data 20 0 247m 37m 6456 R 19,5 1,0 4:02.15 php5-fpm
32469 www-data 20 0 251m 40m 6592 R 19,5 1,0 3:30.46 php5-fpm
32689 www-data 20 0 243m 32m 6816 R 19,2 0,8 2:56.03 php5-fpm
32692 www-data 20 0 251m 41m 6564 R 19,2 1,0 2:57.84 php5-fpm
1115 www-data 20 0 251m 40m 6428 R 18,9 1,0 0:54.01 php5-fpm
1249 www-data 20 0 251m 40m 6356 R 18,9 1,0 0:42.35 php5-fpm
1251 www-data 20 0 250m 39m 6420 R 18,9 1,0 0:37.36 php5-fpm
31314 www-data 20 0 251m 40m 6440 R 18,9 1,0 6:52.49 php5-fpm
32296 www-data 20 0 251m 40m 6560 R 18,9 1,0 4:03.63 php5-fpm
32410 www-data 20 0 251m 40m 6708 R 18,9 1,0 3:53.65 php5-fpm
32468 www-data 20 0 247m 36m 6720 R 18,9 0,9 3:27.14 php5-fpm
32471 www-data 20 0 251m 40m 6472 R 18,9 1,0 3:33.24 php5-fpm
32691 www-data 20 0 251m 40m 6584 R 18,9 1,0 3:03.90 php5-fpm
32294 www-data 20 0 251m 40m 6452 R 18,5 1,0 4:18.55 php5-fpm
32297 www-data 20 0 251m 40m 6456 R 18,5 1,0 4:07.43 php5-fpm
32467 www-data 20 0 246m 35m 6456 R 18,5 0,9 3:41.64 php5-fpm
1250 www-data 20 0 241m 30m 6312 R 18,2 0,8 0:37.06 php5-fpm
32114 www-data 20 0 247m 37m 6428 R 18,2 0,9 4:38.27 php5-fpm
32470 www-data 20 0 243m 32m 6424 R 18,2 0,8 3:30.56 php5-fpm
32527 www-data 20 0 239m 28m 6428 R 18,2 0,7 3:19.96 php5-fpm
1629 root 20 0 17228 5444 1308 S 2,9 0,1 0:01.63 rkhunter
23561 mysql 20 0 488m 73m 7944 S 1,3 1,9 227:34.60 mysqld
4016 root 20 0 23740 1660 1136 R 0,7 0,0 0:00.07 top
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配置(我找了一个例子稍微修改了一下)重写规则是因为旧地址。

server {
listen *:80;

server_name ***.fr www.***.fr;

root /home/www/clients/client1/web7/web/beta/web/;


rewrite ^/index.php / permanent;
rewrite ^/disclaimer.php / permanent;
rewrite ^/disclaimer-mobile.php / permanent;
rewrite ^/news.php /news permanent;
rewrite ^/contact.php /contact permanent;

rewrite ^/app\.php/?(.*)$ /$1 permanent;

try_files $uri @rewriteapp;

location @rewriteapp {
rewrite ^(.*)$ /app.php/$1 last;
}

# Deny all . files
location ~ /\. {
deny all;
}

# Do some static file caching
location ~* \.(jpg|jpeg|gif|png|css|js|ico|xml)$ {
log_not_found off;
expires 1d;
}

location ~ ^/(app|app_dev)\.php(/|$) {
fastcgi_split_path_info ^(.+\.php)(/.*)$;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_index app.php;
send_timeout 1800;
fastcgi_read_timeout 1800;
fastcgi_buffer_size 128k;
fastcgi_buffers 256 16k;
fastcgi_busy_buffers_size 256k;
fastcgi_pass unix:/var/run/php5-fpm.sock;
#fastcgi_pass 127.0.0.1:9000;
}

location ~ ^/(mystatus|myping)$ {
access_log off;
include fastcgi_params;
fastcgi_pass unix:/var/run/php5-fpm.sock;
}


# Statics
location /(bundles|media) {
access_log off;
expires 30d;

# Font files
#if ($filename ~* ^.*?\.(eot)|(ttf)|(woff)$){
# add_header Access-Control-Allow-Origin *;
#}

try_files $uri @rewriteapp;
}
}

最后,PHP-FPM 配置。

pm = dynamic
pm.max_children = 20
pm.start_servers = 10
pm.min_spare_servers = 8
pm.max_spare_servers = 15
pm.max_requests = 400

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

该网站相当“轻”。没有太多的用户交互,只有简单的页面(主要是画廊),所以只是页面生成。

非常感谢

可能(或不)重要的一件事当我重新加载 php5-fpm 时,负载电荷非常平静 (~2),但它会随着时间的推移而放大,直到不低于 8。

进化我用 nginx fastcgi_cache 参数设置了一个缓存。每个页面缓存 5 分钟。这将打破所有“查看”计数器,但我不在乎,因为该网站显然更快。我注意到现在,当我执行 service php5-fpm reload 时,服务器将下降到 1 负责!即使同时有 +100 位访客,它也会继续这样。但奇怪的是,昨天有一次,又开始涨了,收费20。我确实重新加载了 php5-fpm 并且它全部下降到 1 !从昨天开始,它就在 1 上工作。似乎有某种触发点让 php-fpm 变得疯狂!

最佳答案

在使用新设置一周后,以下是我为提高服务器性能所做的工作。

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

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

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

服务器现在非常稳定,CPU 负载大约为 2。我想我已经解决了!

关于php - 拥有 +100 个用户的 Symfony2 网站 = 100% CPU 费用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20205109/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com