648540858 / wvp-GB28181-pro

WEB VIDEO PLATFORM是一个基于GB28181-2016标准实现的网络视频平台,支持NAT穿透,支持海康、大华、宇视等品牌的IPC、NVR、DVR接入。支持国标级联,支持rtsp/rtmp等视频流转发到国标平台,支持rtsp/rtmp等推流转发到国标平台。
https://doc.wvp-pro.cn
MIT License
4.82k stars 1.43k forks source link

技术咨询:推流成功后,推流列表不显示,其他功能列表也不显示. #1580

Closed CaiJinHao closed 2 weeks ago

CaiJinHao commented 1 month ago

环境信息:

相关配置

# 作为28181服务器的配置
sip:
    # [必须修改] 本机的IP,对应你的网卡,监听什么ip就是使用什么网卡,
    # 如果要监听多张网卡,可以使用逗号分隔多个IP, 例如: 192.168.1.4,10.0.0.4
    # 如果不明白,就使用0.0.0.0,大部分情况都是可以的
    # 请不要使用127.0.0.1,任何包括localhost在内的域名都是不可以的。
    ip: ${WVP_HOST:0.0.0.0}
    # [可选] 28181服务监听的端口
    port: ${WVP_PORT:5060}
    # 根据国标6.1.2中规定,domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码(由省级、市级、区级、基层编号组成,参照GB/T 2260-2007)
    # 后两位为行业编码,定义参照附录D.3
    # 3701020049标识山东济南历下区 信息行业接入
    # [可选]
    domain: ${WVP_DOMAIN:3402000000}
    # [可选]
    id: ${WVP_ID:34020000002000000001}
    # [可选] 默认设备认证密码,后续扩展使用设备单独密码, 移除密码将不进行校验
    password: ${WVP_PWD:admin123}

zlm 默认服务器配置

media:
    # [必须修改] zlm服务器唯一id,用于触发hook时区别是哪台服务器,general.mediaServerId
    id: d9eb2d1925cc
    # [必须修改] zlm服务器的内网IP
    ip: ${ZLM_HOST:0.0.0.0}
    # [必须修改] zlm服务器的http.port
    http-port: ${ZLM_PORT:80}
    # [可选] zlm服务器的hook.admin_params=secret
    secret: 035c73f7-bb6b-4889-a715-d9eb2d1925cc
    # 启用多端口模式, 多端口模式使用端口区分每路流,兼容性更好。 单端口使用流的ssrc区分, 点播超时建议使用多端口测试
    rtp:
        # [可选] 是否启用多端口模式, 开启后会在portRange范围内选择端口用于媒体流传输
        enable: true
        # [可选] 在此范围内选择端口用于媒体流传输,
        port-range: 30000,30500 # 端口范围
        # [可选] 国标级联在此范围内选择端口发送媒体流,
        send-port-range: 30000,30500 # 端口范围
    # 录像辅助服务, 部署此服务可以实现zlm录像的管理与下载, 0 表示不使用
    record-assist-port: 18081
    sdp-ip: ${sip.ip:0.0.0.0}
    stream-ip: ${sip.ip:0.0.0.0}

内容描述: 推流使用 ffmpeg-python import ffmpeg

创建 FFmpeg 流

process = ( ffmpeg .input('pipe:0', format='rawvideo', pix_fmt='bgr24', s=f'{width}x{height}', r=fps) .output(rtmp_url, format='flv', video_bitrate='5000k') .run_async(pipe_stdin=True) ) process.stdin.write(frame.tobytes())

截图
推流截图 推流地址:rtmp://172.30.180.228/test/live image 播放截图 播放地址:rtmp://172.30.180.228/test/live?secret=035c73f7-bb6b-4889-a715-d9eb2d1925cc image

抓包文件

日志

无日志
在推流之前我将挂载的logs文件下的日志全部删除掉了。推流成功之后没有任何日志
648540858 commented 2 weeks ago

提供下wvp的日志文件,确定下zlm连接到了wvp里,如果你自己改过zlm的hook,并且关闭了wvp的自动配置,那么wvp不会收到推流消息。

CaiJinHao commented 2 weeks ago

这是推送流得日志: wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:03.154 [wvp-11] INFO --- c.g.iot.vmp.media.zlm.ZLMMediaServerStatusManger: 110 [ZLM-HOOK事件-心跳] ID:xR9DPNt9yn9eYZcX wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.067 I [MediaServer] [832-event poller 17] RtmpProtocol.cpp:442 check_C1_Digest | check rtmp complex handshark success! wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.161 [http-nio-18080-exec-1] INFO --- c.genersoft.iot.vmp.media.zlm.ZLMHttpHookListener: 175 [ZLM HOOK]推流鉴权:xR9DPNt9yn9eYZcX->OnPublishHookParam{id='9-163', app='live', stream='test', ip='172.30.176.1', params='sign=41db35390ddad33f83944f44b8b75ded', port=65064, schema='rtmp', vhost='defaultVhost'} wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.166 [http-nio-18080-exec-1] INFO --- c.genersoft.iot.vmp.media.zlm.ZLMHttpHookListener: 187 [ZLM HOOK]推流鉴权 响应:xR9DPNt9yn9eYZcX->OnPublishHookParam{id='9-163', app='live', stream='test', ip='172.30.176.1', params='sign=41db35390ddad33f83944f44b8b75ded', port=65064, schema='rtmp', vhost='defaultVhost'}->>>>HookResultForOnPublish{enable_audio=true, enable_mp4=true, mp4_max_second=0, mp4_save_path='null', stream_replace='null', modify_stamp='null'} wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.170 D [MediaServer] [832-event poller 17] RtmpSession.cpp:128 operator() | 9-163(172.30.176.1:65064) publish 回复时间:11ms wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.190 W [MediaServer] [832-event poller 17] Factory.cpp:109 getVideoCodecIdByAmf | Unsupported codec: 2 wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.190 W [MediaServer] [832-event poller 17] Rtmp.cpp:299 parseVideoRtmpPacket | Rtmp video codec not supported: 2 wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.190 W [MediaServer] [832-event poller 17] Factory.cpp:118 getTrackByCodecId | Unsupported codec: invalid wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:05.190 I [MediaServer] [832-event poller 17] MediaSource.cpp:476 emitEvent | 媒体注册:rtmp://defaultVhost/live/test wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:13.155 [wvp-12] INFO --- c.g.iot.vmp.media.zlm.ZLMMediaServerStatusManger: 110 [ZLM-HOOK事件-心跳] ID:xR9DPNt9yn9eYZcX wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:23.155 [wvp-13] INFO --- c.g.iot.vmp.media.zlm.ZLMMediaServerStatusManger: 110 [ZLM-HOOK事件-心跳] ID:xR9DPNt9yn9eYZcX wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:25.191 [http-nio-18080-exec-5] INFO --- c.genersoft.iot.vmp.media.zlm.ZLMHttpHookListener: 255 [ZLM HOOK]流无人观看:xR9DPNt9yn9eYZcX->rtmp->live/test wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:33.157 [wvp-14] INFO --- c.g.iot.vmp.media.zlm.ZLMMediaServerStatusManger: 110 [ZLM-HOOK事件-心跳] ID:xR9DPNt9yn9eYZcX wvp-gb28181-pro-wvp-1 | 2024-08-28 17:02:43.159 [wvp-15] INFO --- c.g.iot.vmp.media.zlm.ZLMMediaServerStatusManger: 110 [ZLM-HOOK事件-心跳] ID:xR9DPNt9yn9eYZcX

我没有修改wvp得自动配置。zlm得hook也是用得默认得,我是docker 构建启动得。我看到构建文件中使用得是gitee中得源码直接构建得;我查询到zlm得hook 没有配置任何url。我在哪能找到wvp得hook相关得配置地址。希望能给个参考,感谢; [hook] alive_interval=30.000000 enable=0 on_flow_report= on_http_access= on_play= on_publish= on_record_mp4= on_record_ts= on_rtp_server_timeout= on_rtsp_auth= on_rtsp_realm= on_send_rtp_stopped= on_server_exited= on_server_keepalive= on_server_started= on_shell_login= on_stream_changed= on_stream_none_reader= on_stream_not_found= retry=1 retry_delay=3.000000 stream_changed_schemas=rtsp/rtmp/fmp4/ts/hls/hls.fmp4 timeoutSec=10

CaiJinHao commented 2 weeks ago

我通过zlm得api 接口获取到hook地址是自动配置得,这是当前得配置: http://172.30.180.228/index/api/getServerConfig?secret=5u8dRzNxIBb6A5sfly8EvuRO5v4IgBs9 { "code": 0, "data": [ { "api.apiDebug": "1", "api.defaultSnap": "./www/logo.png", "api.downloadRoot": "./www", "api.secret": "5u8dRzNxIBb6A5sfly8EvuRO5v4IgBs9", "api.snapRoot": "./www/snap/", "cluster.origin_url": "", "cluster.retry_count": "3", "cluster.timeout_sec": "15", "ffmpeg.bin": "/usr/bin/ffmpeg", "ffmpeg.cmd": "%s -re -i %s -c:a aac -strict -2 -ar 44100 -ab 48k -c:v libx264 -f flv %s", "ffmpeg.log": "./ffmpeg/ffmpeg.log", "ffmpeg.restart_sec": "0", "ffmpeg.snap": "%s -rtsp_transport tcp -i %s -y -f mjpeg -frames:v 1 %s", "general.broadcast_player_count_changed": "0", "general.check_nvidia_dev": "1", "general.enableVhost": "0", "general.enable_ffmpeg_log": "0", "general.flowThreshold": "1024", "general.listen_ip": "::", "general.maxStreamWaitMS": "15000", "general.mediaServerId": "xR9DPNt9yn9eYZcX", "general.mergeWriteMS": "0", "general.resetWhenRePlay": "1", "general.streamNoneReaderDelayMS": "20000", "general.unready_frame_cache": "100", "general.wait_add_track_ms": "3000", "general.wait_track_ready_ms": "10000", "hls.broadcastRecordTs": "0", "hls.deleteDelaySec": "10", "hls.fastRegister": "0", "hls.fileBufSize": "65536", "hls.segDelay": "0", "hls.segDur": "2", "hls.segKeep": "0", "hls.segNum": "3", "hls.segRetain": "5", "hook.alive_interval": "10.0", "hook.enable": "1", "hook.on_flow_report": "", "hook.on_http_access": "", "hook.on_play": "http://172.30.180.228:18080/index/hook/on_play", "hook.on_publish": "http://172.30.180.228:18080/index/hook/on_publish", "hook.on_record_mp4": "http://172.30.180.228:18080/index/hook/on_record_mp4", "hook.on_record_ts": "", "hook.on_rtp_server_timeout": "http://172.30.180.228:18080/index/hook/on_rtp_server_timeout", "hook.on_rtsp_auth": "", "hook.on_rtsp_realm": "", "hook.on_send_rtp_stopped": "http://172.30.180.228:18080/index/hook/on_send_rtp_stopped", "hook.on_server_exited": "", "hook.on_server_keepalive": "http://172.30.180.228:18080/index/hook/on_server_keepalive", "hook.on_server_started": "http://172.30.180.228:18080/index/hook/on_server_started", "hook.on_shell_login": "", "hook.on_stream_changed": "http://172.30.180.228:18080/index/hook/on_stream_changed", "hook.on_stream_none_reader": "http://172.30.180.228:18080/index/hook/on_stream_none_reader", "hook.on_stream_not_found": "http://172.30.180.228:18080/index/hook/on_stream_not_found", "hook.retry": "1", "hook.retry_delay": "3.000000", "hook.stream_changed_schemas": "rtsp/rtmp/fmp4/ts/hls/hls.fmp4", "hook.timeoutSec": "30", "http.allow_cross_domains": "1", "http.allow_ip_range": "::1,127.0.0.1,172.16.0.0-172.31.255.255,192.168.0.0-192.168.255.255,10.0.0.0-10.255.255.255", "http.charSet": "utf-8", "http.dirMenu": "1", "http.forbidCacheSuffix": "", "http.forwarded_ip_header": "", "http.keepAliveSecond": "15", "http.maxReqSize": "40960", "http.notFound": "404 Not Found<body bgcolor=\"white\">

您访问的资源不存在!


ZLMediaKit(git hash:6889afb/2024-08-14T20:11:24+08:00,branch:master,build time:2024-08-16T05:04:24)
", "http.port": "80", "http.rootPath": "./www", "http.sendBufSize": "65536", "http.sslport": "443", "http.virtualPath": "", "multicast.addrMax": "239.255.255.255", "multicast.addrMin": "239.0.0.0", "multicast.udpTTL": "64", "protocol.add_mute_audio": "1", "protocol.auto_close": "0", "protocol.continue_push_ms": "3000", "protocol.enable_audio": "1", "protocol.enable_fmp4": "1", "protocol.enable_hls": "1", "protocol.enable_hls_fmp4": "0", "protocol.enable_mp4": "0", "protocol.enable_rtmp": "1", "protocol.enable_rtsp": "1", "protocol.enable_ts": "1", "protocol.fmp4_demand": "0", "protocol.hls_demand": "0", "protocol.hls_save_path": "./www", "protocol.modify_stamp": "2", "protocol.mp4_as_player": "0", "protocol.mp4_max_second": "3600", "protocol.mp4_save_path": "./www", "protocol.paced_sender_ms": "0", "protocol.rtmp_demand": "0", "protocol.rtsp_demand": "0", "protocol.ts_demand": "0", "record.appName": "record", "record.enableFmp4": "0", "record.fastStart": "0", "record.fileBufSize": "65536", "record.fileRepeat": "0", "record.sampleMS": "500", "rtmp.directProxy": "1", "rtmp.enhanced": "0", "rtmp.handshakeSecond": "15", "rtmp.keepAliveSecond": "15", "rtmp.port": "1935", "rtmp.sslport": "19350", "rtp.audioMtuSize": "600", "rtp.h264_stap_a": "1", "rtp.lowLatency": "0", "rtp.rtpMaxSize": "10", "rtp.videoMtuSize": "1400", "rtp_proxy.dumpDir": "", "rtp_proxy.gop_cache": "1", "rtp_proxy.h264_pt": "98", "rtp_proxy.h265_pt": "99", "rtp_proxy.opus_pt": "100", "rtp_proxy.port": "10000", "rtp_proxy.port_range": "30000-30500", "rtp_proxy.ps_pt": "96", "rtp_proxy.rtp_g711_dur_ms": "100", "rtp_proxy.timeoutSec": "15", "rtp_proxy.udp_recv_socket_buffer": "4194304", "rtsp.authBasic": "0", "rtsp.directProxy": "1", "rtsp.handshakeSecond": "15", "rtsp.keepAliveSecond": "15", "rtsp.lowLatency": "0", "rtsp.port": "554", "rtsp.rtpTransportType": "-1", "rtsp.sslport": "332", "shell.maxReqSize": "1024", "shell.port": "9000", "srt.latencyMul": "4", "srt.pktBufSize": "8192", "srt.port": "9000", "srt.timeoutSec": "5" } ] }