Home
Document
Q&A
Video
Donate
Source Code
Code-Galaxy 云原生平台
Business
Swoole Tracker
Swoole Compiler
Login
Register
全部
提问
分享
讨论
建议
公告
开发框架
发表新帖
worker进程出现随机卡死现象
### 问题描述 生产环境时,worker进程会出现cpu 占用过高, 之后进程出现卡死现象 ### Swoole版本,PHP版本,以及操作系统版本信息 用的hyperf1.1 框架, swoole 版本4.5+ PHP版本7.2.33 操作系统版本: docker Alpine Linux 3.9 ### 相关代码 堆栈信息  进程一直在睡眠  cpu 占用 相比其它worker 进程过高, 只有cpu占用过高的进程会发现卡死现象  ### 你期待的结果是什么?实际看到的错误信息又是什么? 在生产环境观察几天后发现, worker 进程 每40分钟左右会重启一次, 但是某个worker 进程 在被卡死的时候 不会被重启, 需要手动杀死, 卡死的进程会一直占用CPU不释放
发布于1年前 · 18 次浏览 · 来自
开发框架
r
rock2018
### 问题描述 生产环境时,worker进程会出现cpu 占用过高, 之后进程出现卡死现象 ### Swoole版本,PHP版本,以及操作系统版本信息 用的hyperf1.1 框架, swoole 版本4.5+ PHP版本7.2.33 操作系统版本: docker Alpine Linux 3.9 ### 相关代码 堆栈信息  进程一直在睡眠  cpu 占用 相比其它worker 进程过高, 只有cpu占用过高的进程会发现卡死现象  ### 你期待的结果是什么?实际看到的错误信息又是什么? 在生产环境观察几天后发现, worker 进程 每40分钟左右会重启一次, 但是某个worker 进程 在被卡死的时候 不会被重启, 需要手动杀死, 卡死的进程会一直占用CPU不释放
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
评论
2020-09-29
r
rock2018
 根据堆栈信息排查 swoole 的138 行的代码 怀疑是参数传入有问题,排查自身服务的代码后发现:  目前怀疑是变量赋值为null, 再通过& 去引用, 此时swoole 调用该代码 _this->private_data_ 的值 实际是null void Context::context_func(void *arg) { Context *_this = (Context *) arg; _this->fn_(_this->private_data_); _this->end_ = true; _this->swap_out(); } 先记录下来,明天验证一下
赞
0
回复
微信公众号
热门内容
- swoole针对400的请求--TRACE Port_onRead_http() (ERRNO 7102): Bad Request: unknown protocol from session#193 on 0.0.0.0:9505
- 基于Swoole+PHP的超高性能短信网关(CMPP、SMPP)模拟器
- http服务中,使用write分段输出文件。设置header总文件长度无用
- Call to undefined function Swoole\Coroutine\run() 是怎么回事啊?
- Swoole Loader扩展 如何下载,https://business.swoole.com/trial/download/ 404
- 请教当使用request主动推送的时候,产生新的连接,及会马上关闭连接问题
- 为什么连接池只创建一个连接
- timer定时器,启动一下,突然执行了1万多次,这是怎么回事呢?
- 在swoole 中, 使用地址引用自身,造成内存增加
- windows 配置wss链接,链接不成功
暂无回复的问答
- 关于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]
- 请问那个一键协程化的代码是放外面还是set里面
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。