wvp 推拉转级联时频繁出现流无法观看的解决办法

经观察,推拉转任务在两三天时间内就失效了。

1 用脚本每天定时启动一次 wvp docker 容器, 并关闭所有推拉转任务,建议每天凌晨2点运行

复制代码
import subprocess
import time
import socket
import requests


def restart_container(container_name):
    subprocess.run(["docker", "restart", container_name], check=True)

def wait_for_port(host, port, timeout=120):
    start_time = time.time()
    while time.time() - start_time < timeout:
        with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as sock:
            result = sock.connect_ex((host, port))
            if result == 0:
                return True
            time.sleep(1)
    return False

container_name = "wvp-server"
port = 48080
host = "localhost"  # 修改为服务所在的主机名或 IP 地址

# 重启 Docker 容器
restart_container(container_name)

# 等待服务端口启动
if wait_for_port(host, port):
    print(f"服务 {container_name} 在端口 {port} 上已启动成功")
else:
    print(f"服务 {container_name} 在端口 {port} 启动失败")


time.sleep(60)


# 目标 URL
url = 'http://127.0.0.1:48080/api/user/login?username=admin&password=21232f297a57a5a743894a0e4a801fc3'  # 替换为实际的 URL

# 发起 GET 请求
response = requests.get(url)

headers = {}
# 检查响应状态码
if response.status_code == 200:
    # 成功处理响应数据
    data = response.json()  # 如果响应内容是 JSON 格式
    headers['Access-Token'] = data['data']['accessToken']
    print("请求成功:", data)
else:
    print("请求失败,状态码:", response.status_code)


# 发起 GET 请求,并添加请求头
response = requests.get('http://127.0.0.1:48080/api/proxy/list?page=1&count=100', headers=headers)


task_list = []
# 检查响应状态码
if response.status_code == 200:
    # 成功处理响应数据
    data = response.json()  # 如果响应内容是 JSON 格式
    task_list = data['data']['list']
    print("请求成功:", data)
else:
    print("请求失败,状态码:", response.status_code)



for task in task_list:
	if task.get('enable', False): 
		print(f"任务 {task['name']} 已启用") 
		response = requests.get(f"http://127.0.0.1:48080/api/proxy/stop?app={task['app']}&stream={task['stream']}", headers=headers) 
		data = response.json()
		print("请求关闭结果---> :", data)
	else: 
		print(f"任务 {task['name']} 未启用")

2 用脚本定时启动未启用的推拉转任务(防止在启动容器时有的流没打开),建议五分钟执行一次

复制代码
import subprocess
import time
import socket
import requests


# 目标 URL
url = 'http://127.0.0.1:48080/api/user/login?username=admin&password=21232f297a57a5a743894a0e4a801fc3'  # 替换为实际的 URL

# 发起 GET 请求
response = requests.get(url)

headers = {}
# 检查响应状态码
if response.status_code == 200:
    # 成功处理响应数据
    data = response.json()  # 如果响应内容是 JSON 格式
    headers['Access-Token'] = data['data']['accessToken']
    print("请求成功:", data)
else:
    print("请求失败,状态码:", response.status_code)


# 发起 GET 请求,并添加请求头
response = requests.get('http://127.0.0.1:48080/api/proxy/list?page=1&count=100', headers=headers)


task_list = []
# 检查响应状态码
if response.status_code == 200:
    # 成功处理响应数据
    data = response.json()  # 如果响应内容是 JSON 格式
    task_list = data['data']['list']
    print("请求成功:", data)
else:
    print("请求失败,状态码:", response.status_code)



for task in task_list:
	if task.get('enable', False): 
		print(f"任务 {task['name']} 已启用") 
	else: 
		print(f"任务 {task['name']} 未启用")
		response = requests.get(f"http://127.0.0.1:48080/api/proxy/start?app={task['app']}&stream={task['stream']}", headers=headers) 
		data = response.json()
		print("请求打开结果---> :", data)
相关推荐
春日见23 分钟前
Tool文件夹:瑞士军刀库
运维·服务器·windows·深度学习·自动驾驶
AI逐月28 分钟前
解决 ComfyUI 插件安装后 Nanobind 报错问题:soxr 版本冲突原理解读
开发语言·python
AC赳赳老秦28 分钟前
Windows 系统 OpenClaw 执行策略报错及管理员权限设置深度解析与实操指南
运维·人工智能·python·django·自动化·媒体·openclaw
Gofarlic_OMS37 分钟前
SolidEdge专业许可证管理工具选型关键评估标准
java·大数据·运维·服务器·人工智能
软件开发技术深度爱好者1 小时前
用python + pillow实现GUI界面图片GUI处理工具
开发语言·python
FreakStudio1 小时前
ESP32 实现在线动态安装库和自动依赖安装-使用uPyPI包管理平台
python·单片机·嵌入式·面向对象·电子diy·sourcetrail
三万棵雪松1 小时前
【Linux 物联网网关主控系统-Linux主控部分(三)】
linux·物联网·嵌入式linux
萝卜白菜。1 小时前
TongWeb7.0 集中管理heimdall配置文件说明
linux·运维·服务器
别抢我的锅包肉1 小时前
【FastAPI】 响应类型详解:从默认 JSON 到自定义响应
python·fastapi
智算菩萨2 小时前
【Tkinter】15 样式与主题深度解析:ttk 主题系统、Style 对象与跨平台样式管理实战
开发语言·python·ui·ai编程·tkinter