首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
swoole的master worker模式,能否动态调整worker数量?
几个比较特殊的问题: worker和task_worker都属于管理进程派生的子进程,用于处理实际的业务流程。 如果每个请求需要耗时100ms(每个进程每秒处理10个请求), 要达到500 rps, 则需要开启50个进程。但是swoole使用的是固定进程数的模式,但这种方式,在实际生产环境中,还有一些问题的。 这对于一些存在访问量突增的环境,为了保证所有请求都能被处理,会有两个严重的问题: 1. 访问量较大时,进程数可能不够,造成请求无法被处理。 2. 访问量降低时,空闲进程过多,导致大量内存被白白占用。 所设你是老板,平时工作太繁忙了,这时候就得多招聘一些临时人员,以免影响进度。但现在进入淡季了,业务量还很少,你难道还会养大量的空闲的临时人员吗? swoole能否根据工作负载,调整worker数量? 类似apache prefork或php-fpm的工作模式? 如果可行,需要用什么方式实现呢?
发布于7年前 · 4 次浏览 · 来自
提问
小
小祖宗
几个比较特殊的问题: worker和task_worker都属于管理进程派生的子进程,用于处理实际的业务流程。 如果每个请求需要耗时100ms(每个进程每秒处理10个请求), 要达到500 rps, 则需要开启50个进程。但是swoole使用的是固定进程数的模式,但这种方式,在实际生产环境中,还有一些问题的。 这对于一些存在访问量突增的环境,为了保证所有请求都能被处理,会有两个严重的问题: 1. 访问量较大时,进程数可能不够,造成请求无法被处理。 2. 访问量降低时,空闲进程过多,导致大量内存被白白占用。 所设你是老板,平时工作太繁忙了,这时候就得多招聘一些临时人员,以免影响进度。但现在进入淡季了,业务量还很少,你难道还会养大量的空闲的临时人员吗? swoole能否根据工作负载,调整worker数量? 类似apache prefork或php-fpm的工作模式? 如果可行,需要用什么方式实现呢?
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2017-04-28
s
sillyboy
swoole使用静态配置,不支持动态调整进程数量。 动态调整进程数量的意义并不大,功能鸡肋而且可能会带来各种问题,所以swoole并不支持它。
赞
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一直是同一个。没用使用到多进程啊。