首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
如何让 Swoole\Process\Pool worker 进程优雅退出
### 问题描述 默认 swoole pool 主进程被 kill 后 worker 进程也会直接退出。有没有办法让 worker 进程完成任务后才退出。 ### Swoole版本,PHP版本,以及操作系统版本信息 ### 相关代码 ```php <?php $pool = new Swoole\Process\Pool(1); $pool->on('workerStart', function (Swoole\Process\Pool $pool, int $workerId) { $stopped = false; pcntl_signal(SIGTERM, function() use (&$stopped) { error_log("receive terminal signal", 3, '/tmp/run.log'); $stopped = true; }); $id = 0; while (!$stopped) { $id++; error_log("work with job $id"); sleep(4); error_log("finish job $id"); } $pool->shutdown(); }); error_log("pid=" . getmypid()); $pool->start(); ``` 在这个程序中如何让 worker 进程输出 finish job 日志后才退出。这个程序对 SIGTERM 的捕获没有作用,怎么才能捕获到 SIGTERM 信号? ### 你期待的结果是什么?实际看到的错误信息又是什么?
发布于4年前 · 13 次浏览 · 来自
提问
wenbinye
### 问题描述 默认 swoole pool 主进程被 kill 后 worker 进程也会直接退出。有没有办法让 worker 进程完成任务后才退出。 ### Swoole版本,PHP版本,以及操作系统版本信息 ### 相关代码 ```php <?php $pool = new Swoole\Process\Pool(1); $pool->on('workerStart', function (Swoole\Process\Pool $pool, int $workerId) { $stopped = false; pcntl_signal(SIGTERM, function() use (&$stopped) { error_log("receive terminal signal", 3, '/tmp/run.log'); $stopped = true; }); $id = 0; while (!$stopped) { $id++; error_log("work with job $id"); sleep(4); error_log("finish job $id"); } $pool->shutdown(); }); error_log("pid=" . getmypid()); $pool->start(); ``` 在这个程序中如何让 worker 进程输出 finish job 日志后才退出。这个程序对 SIGTERM 的捕获没有作用,怎么才能捕获到 SIGTERM 信号? ### 你期待的结果是什么?实际看到的错误信息又是什么?
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2020-07-26
鲁飞
请认真看文档 https://wiki.swoole.com/#/process_pool?id=start 信号处理部分。 你需要加上`pcntl_signal_dispatch();`
赞
1
回复
微信公众号
热门内容
暂无回复的问答
- 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一直是同一个。没用使用到多进程啊。