looking接口可拉取已挂流

This commit is contained in:
wenxin 2024-12-24 19:47:44 +08:00
parent 481700736f
commit fcf3dbc1c0
3 changed files with 22 additions and 23 deletions

View File

@ -1,6 +1,5 @@
from fastapi import APIRouter from fastapi import APIRouter
from app.services.stream_manager import reset_stream_time from app.services.ffmpeg_service import stream_rtsp_to_url, reset_stream_time
from app.services.ffmpeg_service import stream_rtsp_to_url
from linxyun.utils.result import Result, SysCodes from linxyun.utils.result import Result, SysCodes
from app.model import Stream from app.model import Stream
router = APIRouter() router = APIRouter()
@ -12,7 +11,7 @@ async def get_stream(camera_id: str, stream: Stream = Stream(), type: str="flv",
@router.get("/looking/{camera_id}") @router.get("/looking/{camera_id}")
async def looking(camera_id: str): async def looking(camera_id: str):
status = reset_stream_time(camera_id) status = await reset_stream_time(camera_id)
if status is True: if status is True:
return Result.ok() return Result.ok()
else: else:

View File

@ -12,6 +12,21 @@ from app.model import Stream
logger = get_logger(__name__) logger = get_logger(__name__)
test_url = "rtsp://admin:jitu0818@192.168.4.102:554/Streaming/Channels/101" test_url = "rtsp://admin:jitu0818@192.168.4.102:554/Streaming/Channels/101"
async def reset_stream_time(stream_id: str) -> bool:
if stream_id in stream_manager:
new_time = int(time.time() * 1000)
logger.info(f"Stream {stream_id} reset time to {new_time}")
stream = stream_manager[stream_id]
process = stream["process"]
if process.poll() is not None:
# 流已经停止,重启流
result = await start_stream(stream_id, stream["output_url"], stream["config"])
if result is None:
return False
stream["create_time"] = new_time
return True
return False
async def log_output(process, output_url): async def log_output(process, output_url):
try: try:
while True: while True:
@ -55,30 +70,22 @@ async def start_stream(stream_id: str, output_url: str, stream: Stream):
logger.error(f"Failed to start ffmpeg process for {stream_id}: {e}") logger.error(f"Failed to start ffmpeg process for {stream_id}: {e}")
return None return None
# 等待短时间以确认进程是否启动成功
# await asyncio.sleep(10) # 等待 1 秒,确保进程已稳定运行
# 检查进程是否已退出
# if process.poll() is not None: # poll() 检查子进程状态
# logger.error(f"Stream {stream_id} failed to start. Exit code: {process.poll()}")
# stderr_output = await asyncio.to_thread(process.stderr.read)
# logger.error(f"Error: {stderr_output.decode().strip()}")
# return None
# 异步记录输出 # 异步记录输出
asyncio.create_task(log_output(process, output_url)) asyncio.create_task(log_output(process, output_url))
# 保存进程信息 # 保存进程信息
stream_manager[stream_id] = { stream_manager[stream_id] = {
"process": process, "process": process,
"create_time": int(time.time() * 1000) "create_time": int(time.time() * 1000),
"output_url": output_url,
"config": stream
} }
logger.info(f"Stream {stream_id} started successfully") logger.info(f"Stream {stream_id} started successfully")
return process return process
async def stream_rtsp_to_url(stream_id: str, type: str, stream: Stream): async def stream_rtsp_to_url(stream_id: str, type: str, config: Stream):
md5_route = generate_md5(stream_id) md5_route = generate_md5(stream_id)
output_url = f"{rtmp_url}/{md5_route}" output_url = f"{rtmp_url}/{md5_route}"
# 如果流已经在运行,检查进程是否仍在运行 # 如果流已经在运行,检查进程是否仍在运行
@ -96,7 +103,7 @@ async def stream_rtsp_to_url(stream_id: str, type: str, stream: Stream):
# 如果流未在运行,启动新流 # 如果流未在运行,启动新流
logger.info(f"Stream {stream_id} is not running. Starting new stream.") logger.info(f"Stream {stream_id} is not running. Starting new stream.")
result = await start_stream(stream_id, output_url, stream) result = await start_stream(stream_id, output_url, config)
if result is None: if result is None:
return Result.error(SysCodes.OPERATE_FAIL) return Result.error(SysCodes.OPERATE_FAIL)

View File

@ -4,13 +4,6 @@ stream_manager = {}
logger = get_logger(__name__) logger = get_logger(__name__)
def reset_stream_time(stream_id: str) -> bool:
if stream_id in stream_manager:
new_time = int(time.time() * 1000)
logger.info(f"Stream {stream_id} reset time to {new_time}")
stream_manager[stream_id]["create_time"] = new_time
return True
return False
def stop_stream(stream_id: str): def stop_stream(stream_id: str):
if stream_id in stream_manager: if stream_id in stream_manager: