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)
相关推荐
Fleshy数模3 小时前
玩转OpenCV:视频椒盐噪声处理与图像形态学操作实战
人工智能·opencv·音视频
欲买桂花同载酒5823 小时前
程序人生-Hello’s P2P
运维·服务器·数据库
八月的雨季 最後的冰吻3 小时前
FFmepg-- 38-Jitter Buffer固定值c程序分析
服务器·音视频
程序媛一枚~3 小时前
✨✨✨使用Python,OpenCV及图片拼接生成❤️LOVE❤️字样图,每张小图加随机颜色边框,大图加随机大小随机颜色边框
图像处理·python·opencv·numpy·图像拼接
jyfool3 小时前
Ubuntu 远程桌面配置踩坑实录:从 TightVNC 到 x11vnc 的折腾之旅
linux·运维·ubuntu
MediaTea3 小时前
Python:collections.Counter 常用函数及应用
开发语言·python
如若1233 小时前
flash-attn 安装失败?从报错到成功的完整排雷指南(CUDA 12.8 + PyTorch 2.7)
人工智能·pytorch·python
007张三丰3 小时前
知乎高赞回答爬虫:从零开始,建立你的专属知识库
爬虫·python·知识库·python爬虫·知乎·高赞回答
网硕互联的小客服3 小时前
服务器防火墙是如何区分正常流量和攻击流量?
运维·服务器·网络
安当加密3 小时前
基于 RADIUS 的 Linux 服务器双因子认证:从 FreeRADIUS 到轻量级 ASP 方案的演进
linux·运维·服务器