首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
求问一个关于swoole协程调度的问题
### 问题描述 在看swoole文档的过程中对于swoole协程调度所走过的流程有些不明白的地方 (工作模式为多进程模式) 1.创建一个协程是否从worker进程发起,发送至reactor线程的eventloop结构进行调度?如是,若服务器配置多reactor线程,如何理解文档中描述的swoole协程为单线程调度,是否多个reactor线程均可实现协程调度? 2.协程从worker进程让出至reactor线程之后,在经过调度重新恢复至worker的过程中是否会投递到与之前同一个worker进程中去?
发布于4年前 · 2 次浏览 · 来自
提问
mrquin
### 问题描述 在看swoole文档的过程中对于swoole协程调度所走过的流程有些不明白的地方 (工作模式为多进程模式) 1.创建一个协程是否从worker进程发起,发送至reactor线程的eventloop结构进行调度?如是,若服务器配置多reactor线程,如何理解文档中描述的swoole协程为单线程调度,是否多个reactor线程均可实现协程调度? 2.协程从worker进程让出至reactor线程之后,在经过调度重新恢复至worker的过程中是否会投递到与之前同一个worker进程中去?
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2020-03-24
Twosee
协程永远是在本线程内的 协程对应的reactor调度器就是事件调度器(如epoll, kqueue, poll, select), 是多路复用的技术, 而不是多线程的技术
赞
5
回复
2020-03-24
Rango
协程调度是当前进程内进行的。`Reactor`线程和`Worker`进程有各自的`epoll`事件循环。 `Worker`与`Reactor`之间使用`UnixSocket`通信,也是各自加入自己的`epoll`事件循环中实现协程调度。
赞
5
回复
微信公众号
热门内容
暂无回复的问答
- 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一直是同一个。没用使用到多进程啊。