建立udp广播,使用多线程接收数据,运行一段时间程序被killed

程序功能:用python编写socket广播接收程序,使用了多线程技术接收数据,并将接收到的数据放入队列中,消费者进程判断队列中接收的数据是否满足筛选条件,若满足则将筛选出的数据写入文件中。

出现的问题:程序运行大概3、4天后,out of memory被killed掉,不知道问题出在了哪里。如果需要找出问题,应该从哪几方面debug呢?

 

感觉不太像内存泄漏,而是和文件操作有关。“若满足则将筛选出的数据写入文件中”这句话怎么理解?每次从队列中取到一个符合条件的数据,都是存入新的文件呢,还是存入已经存在的文件?是否有重复打开未关闭的文件呢?

另外,是多进程还是多线程?题主前面说多线程,后面说消费者进程,感觉有点乱。