ossrs / srs-gb28181

GB28181 server based on SRS
https://ossrs.net
MIT License
83 stars 41 forks source link

GB28181接入NVR,跑一段时间后奔溃,进程退出 #1790 #5

Open winlinvip opened 2 years ago

winlinvip commented 2 years ago

描述(Description)

描述你遇到了什么问题(Please description your issue here)

  1. SRS版本(Version): srs-4.0.23
  2. SRS的日志如下(Log):
    
    [2020-06-01 20:11:34.573][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/914353200)! ps_size=4228  complete=8884 

[2020-06-01 20:11:34.573][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/914356800) 64 03 ffffffb7 ffffffaa

[2020-06-01 20:11:34.573][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/914356800)! ps_size=4015 complete=0

[2020-06-01 20:11:34.573][Trace][24225][1045] gb28181: client_id 34020000001320023110@34020000001320023113, unkonw ps data (0x698304/919004400) ffffffe5 41 5a ffffff91

[2020-06-01 20:11:34.573][Trace][24225][1045] gb28181: client_id 34020000001320023110@34020000001320023113 decode ps packet error (0x698304/919004400)! ps_size=1106 complete=0

[2020-06-01 20:11:34.674][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=37005, cur=37007, peer(19.19.19.87, 29928) [2020-06-01 20:11:34.674][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=37007, cur=37006, peer(19.19.19.87, 29928) [2020-06-01 20:11:34.674][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=37006, cur=37008, peer(19.19.19.87, 29928) [2020-06-01 20:11:34.674][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=37010, cur=37012, peer(19.19.19.87, 29928) [2020-06-01 20:11:34.674][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=37012, cur=37011, peer(19.19.19.87, 29928) [2020-06-01 20:11:34.675][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=37011, cur=37013, peer(19.19.19.87, 29928) [2020-06-01 20:11:34.675][Warn][24225][1039][11] gb28181: demix ps stream error:code=3041 : process ps video packet : demux annexb : annexb start code thread [24225][1039]: on_ps_stream() [src/app/srs_app_gb28181.cpp:613][errno=11] thread [24225][1039]: on_rtp_video() [src/app/srs_app_gb28181.cpp:959][errno=11] thread [24225][1039]: annexb_demux() [src/protocol/srs_raw_avc.cpp:56][errno=11] [2020-06-01 20:11:35.645][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=37258, cur=37298, peer(19.19.19.87, 29928) [2020-06-01 20:11:35.645][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x69820a, pre=22271, cur=22276, peer(19.19.19.87, 29930) [2020-06-01 20:11:35.645][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=44270, cur=44277, peer(19.19.19.87, 29940) [2020-06-01 20:11:35.646][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/914403600) ffffffe8 08 05 7c

[2020-06-01 20:11:35.646][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/914403600)! ps_size=47628 complete=61468

[2020-06-01 20:11:35.646][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/914410800) ffffffe7 ffffffd1 ffffffea 6d

[2020-06-01 20:11:35.646][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/914410800)! ps_size=3721 complete=0

[2020-06-01 20:11:35.653][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e108, pre=24180, cur=24183, peer(111.111.111.234, 21104) [2020-06-01 20:11:35.653][Trace][24225][1069] gb28181: client_id chid33743112, unkonw ps data (0x202e108/860420883) 10 ffffffb4 ffffff97 ffffffc4

[2020-06-01 20:11:35.653][Trace][24225][1069] gb28181: client_id chid33743112 decode ps packet error (0x202e108/860420883)! ps_size=52727 complete=55527

[2020-06-01 20:11:39.284][Trace][24225][1027] <- GBS gb28181: client_id , peer(19.19.19.87, 29928) ps rtp packet 1412B, age=1787594259, vt=2/96, sts=38655/914760000/0x698107, paylod=1400B [2020-06-01 20:11:39.574][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=38861, cur=38888, peer(19.19.19.87, 29928) [2020-06-01 20:11:39.574][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x69820a, pre=22725, cur=22728, peer(19.19.19.87, 29930) [2020-06-01 20:11:39.574][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=44906, cur=44913, peer(19.19.19.87, 29940) [2020-06-01 20:11:39.576][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/914774400) ffffffd5 ffffff8f ffffffb0 3f

[2020-06-01 20:11:39.576][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/914774400)! ps_size=2828 complete=18609

[2020-06-01 20:11:39.594][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e108, pre=24617, cur=24619, peer(111.111.111.234, 21104) [2020-06-01 20:11:39.772][Trace][24225][1069] gb28181: client_id chid33743112, unkonw ps data (0x202e108/860812227) ffffff99 3b ffffffc1 ffffffe2

[2020-06-01 20:11:39.773][Trace][24225][1069] gb28181: client_id chid33743112 decode ps packet error (0x202e108/860812227)! ps_size=54363 complete=55763

[2020-06-01 20:11:40.190][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=39016, cur=39024, peer(19.19.19.87, 29928) [2020-06-01 20:11:40.191][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/914814000) 38 4c ffffff8e 35

[2020-06-01 20:11:40.191][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/914814000)! ps_size=7028 complete=15700

[2020-06-01 20:11:40.192][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e108, pre=24748, cur=24750, peer(111.111.111.234, 21104) [2020-06-01 20:11:40.195][Trace][24225][1069] gb28181: client_id chid33743112, unkonw ps data (0x202e108/860909727) 00 00 00 00

[2020-06-01 20:11:40.195][Trace][24225][1069] gb28181: client_id chid33743112 decode ps packet error (0x202e108/860909727)! ps_size=5376 complete=6776

[2020-06-01 20:11:41.042][Trace][24225][1076] <- CPB time=1905310580, okbps=0,0,0, ikbps=1049,1101,1068, mr=0/350, p1stpt=20000, pnt=5000 [2020-06-01 20:11:41.527][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x69820a, pre=22947, cur=22952, peer(19.19.19.87, 29930) [2020-06-01 20:11:41.527][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=39673, cur=39706, peer(19.19.19.87, 29928) [2020-06-01 20:11:41.527][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=45233, cur=45240, peer(19.19.19.87, 29940) [2020-06-01 20:11:41.529][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/914950800) 31 fffffffd 69 ffffffd8

[2020-06-01 20:11:41.529][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/914950800)! ps_size=8428 complete=16715

[2020-06-01 20:11:42.228][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=45370, cur=45372, peer(19.19.19.87, 29940) [2020-06-01 20:11:42.228][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=39851, cur=39857, peer(19.19.19.87, 29928) [2020-06-01 20:11:42.229][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915001200) 00 00 00 00

[2020-06-01 20:11:42.229][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/915001200)! ps_size=11228 complete=15164

[2020-06-01 20:11:42.230][Trace][24225][1045] gb28181: client_id 34020000001320023110@34020000001320023113, unkonw ps data (0x698304/919652400) 00 00 00 01

[2020-06-01 20:11:42.230][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x69820a, pre=23062, cur=23067, peer(19.19.19.87, 29930) [2020-06-01 20:11:42.230][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915004800) 6a 0b ffffff87 fffffffc

[2020-06-01 20:11:42.230][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/915004800)! ps_size=12861 complete=0

[2020-06-01 20:11:43.583][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=40490, cur=40526, peer(19.19.19.87, 29928) [2020-06-01 20:11:43.584][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=45561, cur=45570, peer(19.19.19.87, 29940) [2020-06-01 20:11:43.585][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915130800) 00 00 00 00

[2020-06-01 20:11:43.585][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/915130800)! ps_size=8428 complete=16969

[2020-06-01 20:11:43.586][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x69820a, pre=23170, cur=23177, peer(19.19.19.87, 29930) [2020-06-01 20:11:43.586][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915141600) 00 00 00 01

[2020-06-01 20:11:43.604][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e108, pre=25098, cur=25101, peer(111.111.111.234, 21104) [2020-06-01 20:11:43.634][Trace][24225][1069] gb28181: client_id chid33743112, unkonw ps data (0x202e108/861187227) 61 31 44 ffffffd5

[2020-06-01 20:11:43.634][Trace][24225][1069] gb28181: client_id chid33743112 decode ps packet error (0x202e108/861187227)! ps_size=52855 complete=55655

[2020-06-01 20:11:44.163][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=45708, cur=45710, peer(19.19.19.87, 29940) [2020-06-01 20:11:44.163][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=40661, cur=40667, peer(19.19.19.87, 29928) [2020-06-01 20:11:44.165][Trace][24225][1045] gb28181: client_id 34020000001320023110@34020000001320023113, unkonw ps data (0x698304/919836000) 00 00 00 00

[2020-06-01 20:11:44.165][Trace][24225][1045] gb28181: client_id 34020000001320023110@34020000001320023113 decode ps packet error (0x698304/919836000)! ps_size=4848 complete=6248

[2020-06-01 20:11:44.166][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915177600) 60 ffffffcd 2c 79

[2020-06-01 20:11:44.166][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/915177600)! ps_size=8105 complete=15105

[2020-06-01 20:11:45.553][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=41329, cur=41365, peer(19.19.19.87, 29928) [2020-06-01 20:11:45.553][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x69820a, pre=23393, cur=23398, peer(19.19.19.87, 29930) [2020-06-01 20:11:45.554][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=45891, cur=45899, peer(19.19.19.87, 29940) [2020-06-01 20:11:45.555][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915310800) 60 37 29 23

[2020-06-01 20:11:45.555][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/915310800)! ps_size=8428 complete=17331

[2020-06-01 20:11:45.795][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e108, pre=25344, cur=25347, peer(111.111.111.234, 21104) [2020-06-01 20:11:45.795][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e108, pre=25347, cur=25345, peer(111.111.111.234, 21104) [2020-06-01 20:11:45.795][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e108, pre=25346, cur=25348, peer(111.111.111.234, 21104) [2020-06-01 20:11:45.797][Warn][24225][1069][11] gb28181: demix ps stream error:code=3041 : process ps video packet : demux annexb : annexb start code thread [24225][1069]: on_ps_stream() [src/app/srs_app_gb28181.cpp:613][errno=11] thread [24225][1069]: on_rtp_video() [src/app/srs_app_gb28181.cpp:959][errno=11] thread [24225][1069]: annexb_demux() [src/protocol/srs_raw_avc.cpp:56][errno=11] [2020-06-01 20:11:46.164][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=41492, cur=41497, peer(19.19.19.87, 29928) [2020-06-01 20:11:46.166][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915357600) ffffff9a ffffffc2 ffffff88 ffffff80

[2020-06-01 20:11:46.166][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111 decode ps packet error (0x698107/915357600)! ps_size=5699 complete=11299

[2020-06-01 20:11:46.166][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=46035, cur=46037, peer(19.19.19.87, 29940) [2020-06-01 20:11:46.166][Trace][24225][1045] gb28181: client_id 34020000001320023110@34020000001320023113, unkonw ps data (0x698304/920016000) ffffffcb fffffffd 6f fffffffc

[2020-06-01 20:11:46.166][Trace][24225][1045] gb28181: client_id 34020000001320023110@34020000001320023113 decode ps packet error (0x698304/920016000)! ps_size=4228 complete=5589

[2020-06-01 20:11:46.575][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e20b, pre=26169, cur=26171, peer(111.111.111.234, 21106) [2020-06-01 20:11:46.575][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e20b, pre=26171, cur=26170, peer(111.111.111.234, 21106) [2020-06-01 20:11:46.575][Trace][24225][1072] gb28181: client_id chid33743371, unkonw ps data (0x202e20b/859935399) ffffff97 5c ffffff87 ffffff95

[2020-06-01 20:11:46.575][Trace][24225][1072] gb28181: client_id chid33743371 decode ps packet error (0x202e20b/859935399)! ps_size=5812 complete=7212

[2020-06-01 20:11:46.668][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x202e20b, pre=26170, cur=26172, peer(111.111.111.234, 21106) [2020-06-01 20:11:46.668][Trace][24225][1072] gb28181: client_id chid33743371, unkonw ps data (0x202e20b/859935399) 59 fffffffb 14 ffffffbd

[2020-06-01 20:11:46.668][Trace][24225][1072] gb28181: client_id chid33743371 decode ps packet error (0x202e20b/859935399)! ps_size=1400 complete=0

[2020-06-01 20:11:47.565][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698107, pre=42141, cur=42179, peer(19.19.19.87, 29928) [2020-06-01 20:11:47.565][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x69820a, pre=23617, cur=23623, peer(19.19.19.87, 29930) [2020-06-01 20:11:47.565][Warn][24225][1027][11] gb28181: ps sequence_number out of order, ssrc=0x698304, pre=46227, cur=46235, peer(19.19.19.87, 29940) [2020-06-01 20:11:47.565][Trace][24225][1042] gb28181: client_id 34020000001320023110@34020000001320023112, unkonw ps data (0x69820a/920253600) 00 00 00 01

[2020-06-01 20:11:47.566][Trace][24225][1039] gb28181: client_id 34020000001320023110@34020000001320023111, unkonw ps data (0x698107/915490800) 00 00 00 01

srs: src/protocol/srs_raw_avc.cpp:80: virtual bool SrsRawH264Stream::is_sps(char*, int): Assertion `nb_frame > 0' failed. ./start_gb28181.sh: line 2: 24225 Aborted /opt/srs/trunk/objs/srs -c /opt/srs/trunk/conf/push.gb28181.conf

1. SRS的配置如下(Config):

push gb28181 stream to SRS.

listen 1935; max_connections 1000; daemon off; srs_log_tank console;

http_api { enabled on; listen 1985; }

http_server { enabled on; listen 8080; dir ./objs/nginx/html; }

stats { network 0; }

stream_caster { enabled on; caster gb28181;

# 转发流到rtmp服务器地址与端口
# TODO: https://github.com/ossrs/srs/pull/1679/files#r400875104
# [stream] is VideoChannelCodecID(视频通道编码ID) for sip
# 自动创建的道通[stream] 是‘chid[ssrc]’ [ssrc]是rtp的ssrc
# [ssrc] rtp中的ssrc
output              rtmp://127.0.0.1:1935/live/[stream];

# 接收设备端rtp流的多路复用端口
listen              9000;

# rtp接收监听端口范围,最小值
rtp_port_min        58200;
# rtp接收监听端口范围,最大值
rtp_port_max        58300;

# 是否等待关键帧之后,再转发,
# off:不需等待,直接转发
# on:等第一个关键帧后,再转发
wait_keyframe       off;

# rtp包空闲等待时间,如果指定时间没有收到任何包
# rtp监听连接自动停止,发送BYE命令
rtp_idle_timeout    30;

# 是否转发音频流
# 目前只支持aac格式,所以需要设备支持aac格式
# on:转发音频
# off:不转发音频,只有视频
# *注意*!!!:flv 只支持11025  22050  44100 三种
# 如果设备端没有三种中任何一个,转发时为自动选择一种格式
# 同时也会将adts的头封装在flv aac raw数据中
# 这样的话播放器为自动通过adts头自动选择采样频率
# 像ffplay, vlc都可以,但是flash是没有声音,
# 因为flash,只支持11025 22050 44100
audio_enable        off;

# 服务器主机号,可以域名或ip地址
# 也就是设备端将媒体发送的地址,如果是服务器是内外网
# 需要写外网地址,
# 调用api创建stream session时返回ip地址也是host
# $CANDIDATE 是系统环境变量,从环境变量获取地址,如果没有配置,用*
# *代表指定stats network 的网卡号地址,如果没有配置network,默认则是第0号网卡地址
# TODO: https://github.com/ossrs/srs/pull/1679/files#r400917594
# host       $CANDIDATE;
host        114.114.189.151;

#根据收到ps rtp包自带创建rtmp媒体通道,不需要api接口创建
#rtmp地址参数[stream] 就是通道id  格式chid[ssrc]
auto_create_channel   on;

sip {
    # 是否启用srs内部sip信令
    # 为on信令走srs, off 只转发ps流
    enabled on;

    # sip监听udp端口
    listen              5060;

    # SIP server ID(SIP服务器ID).
    # 设备端配置编号需要与该值一致,否则无法注册
    serial              34020000001320023101;

    # SIP server domain(SIP服务器域)
    realm               3402000000;

    # 服务端发送ack后,接收回应的超时时间,单位为秒
    # 如果指定时间没有回应,认为失败
    ack_timeout         30;

    # 设备心跳维持时间,如果指定时间内(秒)没有接收一个心跳
    # 认为设备离线
    keepalive_timeout   120;

    # 注册之后是否自动给设备端发送invite
    # on: 是  off 不是,需要通过api控制
    auto_play           on;
    # 设备将流发送的端口,是否固定
    # on 发送流到多路复用端口 如9000
    # off 自动从rtp_mix_port - rtp_max_port 之间的值中
    # 选一个可以用的端口
    invite_port_fixed     on;

    # 向设备或下级域查询设备列表的间隔,单位(秒)
    # 默认60秒
    query_catalog_interval  60;
}

} rtc_server { enabled on;

Listen at udp://8000

listen          8000;
#
# The $CANDIDATE means fetch from env, if not configed, use * as default.
# The * means retrieving server IP automatically, from all network interfaces,
# @see https://github.com/ossrs/srs/issues/307#issuecomment-599028124
candidate       114.114.189.151;

} vhost defaultVhost { http_remux { enabled on; mount [vhost]/[app]/[stream].flv; } rtc { enabled on; bframe discard; } }



**重现(Replay)**

> 重现Bug的步骤(How to replay bug?)

1. `大华NVR接入、科达NVR接入`都存在此问题
码流配置:
![image](https://user-images.githubusercontent.com/11606336/83465794-a43a4f80-a4a7-11ea-91c2-dba195cc3c76.png)
接入配置:

![QQ图片20200602080858](https://user-images.githubusercontent.com/11606336/83466002-53772680-a4a8-11ea-92df-22382932c3b1.png)

**期望行为(Expect)**

> 描述你期望发生的事情(Please describe your expectation)
主进程不要崩溃
winlinvip commented 2 years ago

Migrate from https://github.com/ossrs/srs/issues/1790