问题描述:
最近做直播系统,利用opencv进行图像采集处理,直播推出去的流发现延迟高且会累积延迟.
后面发现是opencv的cap.read()会有一定的缓存,不是读的实时帧.
解决办法:
多进程进行(python多线程不能利用多核,所以处理线程占用高的时候,读取线程会被阻塞)
一个进程进行处理,一个进程进行读取.直接用 Queue列队进行通信.参考文章
读取端进行put,但put之前先判断有多少缓存,然后删除缓存再put;
lenth = que.qsize()
print ("que lenth: ",lenth)
if lenth >2:
for i in range(lenth-2):
frame = que.get() #清除缓存
que.put(img)
处理端get就好.
过程中遇到的问题记录:
1. 使用 multiprocessing.Queue() 后进程不能停止.
解决办法:
manager = multiprocessing.Manager()
que = manager.Queue()