求助 1000 并发量所需服务器配置
求助点:
1.具体服务器几核几G
2.接口域名并发设置大小
3.数据库连接设置大小
我的处理:
1台主服务器 8核 16g 8m带宽
1从服务器 2和2g 2m带宽 (按量付费)
主从服务器环境:
php7.2,(swoole扩展,opcache扩展,redis扩展)
mysql5.6,
nginx1.16.1
框架laravel5.5(因为6.0很多插件不成熟),缓存采用redis,访问量大的表都做了索引处理。图片存储oss,js,css存储oss
主从都采用swoole加速,
主从swoole配置
SWOOLE_HTTP_HOST=127.0.0.1
SWOOLE_MAX_REQUEST=1
SWOOLE_HTTP_WEBSOCKET=false
SWOOLE_HTTP_REACTOR_NUM=16
SWOOLE_HTTP_WORKER_NUM=100
SWOOLE_HTTP_TASK_WORKER_NUM=100
SWOOLE_MAX_REQUEST=3000
我的结果:单页面接口请求返回最大数据150kb,能稳定运行600-800并发;
600并发用户访问流畅(小于3秒),800并发用户访问缓慢(平均8秒)
千万不要被网上的言论带歪了,辟谣:
max_requests
内,内存占用最高的那次 request 所申请的内存」。我的建议是:
在新业务上线前,要得出你需要多大机器,你需要:
(QPS*ART)/NOW=1
。假设 QPS = 1000,ART = 0.1s,那么 NOW 为 100 才能够在理想状态下,刚好满足你的业务需求(也就是所有请求都可以在不排队的情况下完成处理)。
那么为了推算 NOW,你就需要知道 ART。你可以在一台 1 核心 CPU 的机器上跑一下你的业务,PHP-FPM
max_children
保持为 1 即可。随后用压测工具跑单并发,即可计算大概的平均响应时间。务必单线程,否则没有参考价值。得到 NOW,也就是所需的 Worker 数量之后,你就可以开始推算需要多大机器了。
一般来说,Worker 进程不建议超过 CPU 核心数的 2~4 倍。因此你可以使用 NOW / 2 甚至 NOW / 4 得到你所需要的 CPU 核心数。
至于内存,你同样可以在一台内存足够的机器上跑一跑你的业务,
max_children
调大些,通过systemctl
之类的工具观察 FPM Worker 进程的内存占用,得出一个大概内存占用量的大概数值,随后将平均内存占用量 * NOW 即可。最后,在生产环境中,建议你:
htop
等工具观察实际的 CPU 和内存使用率,尤其是 Load Average 的值。