今天一台测试服务器 /tmp
下产生大量 swoole.task 临时文件 大概几十万个 将磁盘打满了 大概时间也就7天以内 , 这些文件什么鬼 ?? 是worker
to task
的队列长度堵塞 生成的文件吗?
在测试服务器上, 有很多 swoole
服务程序, swoole.task 临时文件仍在增长, 所以我就依次 kill
服务. 终于找到问题服务在哪里了
这个服务的 task进程
子进程 manager进程
都已经死掉了.
====================== 活着的进程 ================================
root 4651 11357 0 17:31 pts/0 00:00:00 Knock-swoole-main-master
root 4741 1 0 17:31 pts/0 00:00:07 Knock-swoole-worker-0
====================== 死掉的进程 ================================
root 4652 4651 0 17:31 pts/0 00:00:00 Knock-swoole-main-manager
root 4694 1 0 17:31 pts/0 00:00:00 Knock-sws-swoole-fork-process
root 4740 1 4 17:31 pts/0 00:01:50 Knock-swoole-task-0
总结了下原因如下 :
swoole
起得多进程脚本 worker
投递任务给 task
进程
但 不知什么原因 manager
进程 死掉了 task
进程过期后没有重新拉起worker
投递的数据超过8180
字节 产生了临时文件 (文档)
而且因为投递的任务未执行导致 worker
仍会重复投递 直至磁盘打满
当我想复现下问题, 但因为投递数据不超过 8180字节 所以在kill掉 上述进程后并没有临时文件产生.