python实现实时视频流播放代码实例
作者:前方、有光 发布时间:2021-09-11 21:11:22
标签:python,实时,视频,流,播放
这篇文章主要介绍了python实现实时视频流播放代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
@action(methods=['GET'], detail=True)
def video(self, request, pk=None):
"""
获取设备实时视频流
:param request:
:param pk:
:return:
"""
device_obj = self.get_object()
# if device_obj.status == 0:
# return Response({'error': '设备离线'})
if not device_obj.rtsp_address:
return Response({'error': '缺少rtsp地址'})
cache_id = '_video_stream_{}'.format(device_obj.hash)
cache_status = cache.get(cache_id, None)
if cache_status is None: # 任务初始化,设置初始时间
cache.set(cache_id, time.time(), timeout=60)
elif isinstance(cache_status, float) and time.time() - cache_status > 30: # 任务已超时, 返回错误信息, 一段时间内不再入队
return Response({'error': '连接数目超过限制, 请稍后再试'})
ret = job_queue.enqueue_video(rtsp_address=device_obj.rtsp_address, device_hash=device_obj.hash)
logger.info('fetch device %s video job status: %s', pk, ret._status)
if ret._status == b'started' or 'started': # 视频流正常推送中, 刷新播放时间, 返回视频ID
cache.set(cache_id, 'continue', timeout=30)
return Response({'video': ''.join([settings.FFMPEG_VIDEO, device_obj.hash])})
elif ret._status == b'queued' or 'queued': # 视频任务等待中
return Response({'status': '等待建立视频连接'})
else: # 建立视频任务失败
return Response({'error': '打开视频失败'})
class JobQueue:
"""实时视频播放"""
def __init__(self):
self.video_queue = django_rq.get_queue('video') # 视频推流消息队列
def enqueue_video(self, rtsp_address, device_hash):
"""视频流队列"""
job_id = 'video_{}'.format(device_hash)
job = self.video_queue.fetch_job(job_id)
if not job:
job = self.video_queue.enqueue_call(
func='utils.ffmpeg.ffmpeg_play',
args=(rtsp_address, device_hash),
timeout=-1,
ttl=30, # 最多等待30秒
result_ttl=0,
job_id=job_id
)
return job
# -*- coding: utf-8 -*-
import subprocess
import threading
import time
import logging
from django.core.cache import cache
logger = logging.getLogger('server.default')
def ffmpeg_play(stream, name):
play = True
cache_id = '_video_stream_{}'.format(name)
cache.set(cache_id, 'continue', timeout=30)
process = None
def upstream():
cmd = "ffmpeg -i '{}' -c:v h264 -f flv -r 25 -an 'rtmp://127.0.0.1:1935/live/{}'".format(stream, name)
process = subprocess.Popen(cmd, shell=True, stdin=subprocess.PIPE, stderr=subprocess.DEVNULL)
try:
logger.info('device: {} stream thread start: {}'.format(name, stream))
while play:
time.sleep(1)
except Exception as e:
logger.info('device: {} stream thread error {}'.format(name, e))
finally:
logger.info('device: {} stream thread stop'.format(name))
process.communicate(b'q')
thr = threading.Thread(target=upstream)
thr.start()
try:
while True:
play = cache.get(cache_id, '')
if play != 'continue':
logger.info('stop device {} video stream'.format(name))
play = False
break
time.sleep(1)
except Exception as e:
logger.info('device: {} play stream error {}'.format(name, e))
process.communicate(b'q')
logger.info('wait device {} video thread stop'.format(name))
thr.join()
logger.info('device {} video job stop'.format(name))
# 实时视频流播放
RQ_QUEUES = {
'video': {
'USE_REDIS_CACHE': 'video',
}
}
来源:https://www.cnblogs.com/52-qq/p/11812430.html


猜你喜欢
- HTTPS简介HTTPS(Hyper Text Transfer Protocol Secure),是一种基于SSL/TLS的HTTP,所有
- 本文实例讲述了python爬虫学习笔记之Beautifulsoup模块用法。分享给大家供大家参考,具体如下:相关内容:什么是beautifu
- 这篇文章阐述的是一种函数式编程(functional-programming)设计模式,我称之为惰性函数定义(Lazy Function D
- 在ASP中,如何获得ADO的连接信息? 具体方法见下列代码:<%Sub Connecti
- 本文将以Mysql举例,介绍sqlalchemy的基本用法。其中,Python版本为2.7,sqlalchemy版本为1.1.6。一. 介绍
- 生产系统随着业务增长总会经历一个业务量由小变大的过程,可扩展性是考量数据库系统高可用性的一个重要指标;在单表/数据库数据量过大,更新量不断飙
- 在日常的前端开发工作中,我们会经常的与HTML、javascript、css等语言打交道,和一门真正的语言一样,计算机语言也有它的字母表、语
- 本文实例讲述了python编程开发之类型转换convert。分享给大家供大家参考,具体如下:在python的开发过程中,难免会遇到类型转换,
- 本文实例为大家分享了python爬取微信公众号文章的具体代码,供大家参考,具体内容如下# -*- coding: utf-8 -*-impo
- TTS简介TTS(Text To Speech)是一种语音合成技术,可以让机器将输入文本以语音的方式播放出来,实现机器说话的效果。TTS分成
- 背景:由于需要对ocr识别系统的表格识别结果做验证,通过返回的json文件结果对比比较麻烦,故需要将json文件里面的识别结果还原为表格做验
- 前言爬虫和反爬虫日益成为每家公司的标配系统。爬虫在情报获取、虚假流量、动态定价、恶意攻击、薅羊毛等方面都能起到很关键的作用,所以每家公司都或
- 先看看结果吧,去bilibili上拿到的图片=-=第一步,导入模块import requestsfrom bs4 import Beauti
- Flask-SQLAlchemy安装和建表操作请参考这里。 # Role表class Role(db.Model):
- 代码和代码运行的结果:代码:import itertools as itswords="rot123"a=its.pro
- type 所有类是type生成的a = 1b = "abc"print("type a:{}&qu
- 一、数组的创建方式一var a = new Array(); a[0]="wo"
- 网页可以说是网站构成的基本元素。当我们轻点鼠标,在网海中遨游,一幅幅精彩的网页会呈现在我们面前,那么,网页的精彩与否的因素是什么呢?色彩的搭
- 当模型models.py中发生改变时,即在models.py文件操作数据表,使得数据库中的表结构发生变化,需要使用命令,记录这些操作,类似于
- 在刚接触C#的时候由于公司使用的就是Oracle数据库,那么C#怎么连接Oracle数据库就成了首要去掌握的知识点了。在那时没有ODP.NE