首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
关于worker进程的的合理设置及运行机制
对底层不了解 ,一直不明白,如果我开4个worker,如果一个request 请求需要1s才能返回数据 ,是不是一秒只能处理4个请求了? 还是worker内部有多进程的机制?一个worker同时可以处理多个请求? 这个问题的原因是: 我使用swoole framework创建了一个传统PHP网站项目,并使用swoole http server代替了php fpm, 我知道当运行在fpm模式时,同时能处理的的最大数量QPS是: 平均处理时间为0.5s时 , fpm开200个时,则:QPS = 200 * 1 / 0.5 = 约400qps, 同理在swoole http server模式下,如果我只开4个worker那么,是不是只能有: QPS = 4 * 1 / 0.5 = 8了?这个是忽略swoole http server更好的处理性能的,假设我迁到swoole下获得了10倍的性能提升,也就是80? http://wiki.swoole.com/wiki/page/275.html 参考 此处文档,感觉我也应该像fpm一样设置成 200个worker
发布于7年前 · 2 次浏览 · 来自
提问
在
在路上
对底层不了解 ,一直不明白,如果我开4个worker,如果一个request 请求需要1s才能返回数据 ,是不是一秒只能处理4个请求了? 还是worker内部有多进程的机制?一个worker同时可以处理多个请求? 这个问题的原因是: 我使用swoole framework创建了一个传统PHP网站项目,并使用swoole http server代替了php fpm, 我知道当运行在fpm模式时,同时能处理的的最大数量QPS是: 平均处理时间为0.5s时 , fpm开200个时,则:QPS = 200 * 1 / 0.5 = 约400qps, 同理在swoole http server模式下,如果我只开4个worker那么,是不是只能有: QPS = 4 * 1 / 0.5 = 8了?这个是忽略swoole http server更好的处理性能的,假设我迁到swoole下获得了10倍的性能提升,也就是80? http://wiki.swoole.com/wiki/page/275.html 参考 此处文档,感觉我也应该像fpm一样设置成 200个worker
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2017-05-11
h
hough
这个取决于你的代码怎么写,是同步阻塞还是异步非阻塞 ## 同步阻塞 如果用同步阻塞的写法,Worker进程必须要等待所有IO完成才能发送response,然后再处理下一个请求。一个请求要处理1秒,那4个Worker进程1秒只能处理4个请求。 所以同步模式应该增加进程数量,比如设置200个,那么就可以提供200QPS的处理能力。在swoole_http_server中如果使用同步模式编写代码,那么相比php-fpm,它提升性能的地方主要有2点: 1. swoole_http_server解析http请
赞
0
回复
2017-05-12
新
新用户(手机注册)
测试了下,worker_num调高后,系统调度居然会损失3分之二的性能,实际上像fpm同步阻塞模式,估计也是很大部分性能损失到CPU IO调度上了,
赞
0
回复
微信公众号
热门内容
暂无回复的问答
- CodeGalaxy K3s 轻量集群节点之间如何实现负载均衡
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。