Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

5.0.26版本,设备无法注册 #65

Open
liyuanju opened this issue Oct 31, 2022 · 0 comments
Open

5.0.26版本,设备无法注册 #65

liyuanju opened this issue Oct 31, 2022 · 0 comments

Comments

@liyuanju
Copy link

注意:提问前,请先看FAQ(Please read FAQ before file an issue) ossrs/srs#2716

描述(Description)

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

  1. SRS版本(Version): xxxxxx
    5.0.26
  2. SRS的日志如下(Log):

[2022-10-31 07:08:25.094][Trace][24][04xv12gg] Hybrid cpu=0.00%,17MB, cid=15,7, timer=62,0,0, clock=0,48,1,0,0,0,0,0,0, free=1
[2022-10-31 07:08:26.982][Trace][24][88m120dd] TCP: before dispose resource(RtmpConn)(0x1577160), conns=2, zombies=0, ign=0, inz=0, ind=0
[2022-10-31 07:08:26.982][Error][24][88m120dd][62] serve error code=1011 : rtmp handshake : complex handshake : read c0c1 : read c0c1 : timeout 30000 ms
thread [24][88m120dd]: do_cycle() [src/app/srs_app_rtmp_conn.cpp:167][errno=62]
thread [24][88m120dd]: handshake() [src/protocol/srs_rtmp_stack.cpp:2289][errno=62]
thread [24][88m120dd]: handshake_with_client() [src/protocol/srs_rtmp_handshake.cpp:1170][errno=62]
thread [24][88m120dd]: read_c0c1() [src/protocol/srs_rtmp_stack.cpp:1674][errno=62]
thread [24][88m120dd]: read_fully() [src/protocol/srs_service_st.cpp:557][errno=62](Timer expired)
[2022-10-31 07:08:26.982][Trace][24][eo695751] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2022-10-31 07:08:26.982][Trace][24][88m120dd] TCP: disposing #0 resource(RtmpConn)(0x1577160), conns=2, disposing=1, zombies=0
[2022-10-31 07:08:27.996][Trace][24][6y970d58] HTTP #7 172.17.0.1:55440 GET http://localhost:1985/api/v1/streams/?callback=angular.callbacks._b, content-length=-1
xxxxxxxxxxxx


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

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

http_api {
enabled on;
listen 1985;
}

http_server {
enabled on;
listen 8080;
}

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;
# 多路复用端口类型,on为tcp,off为udp
# 默认:on
tcp_enable            on;

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

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

# 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       192.168.254.xx

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

sip {
    # 是否启用srs内部sip信令
    # 为on信令走srs, off 只转发ps流
    enabled on;
    
    # sip监听udp端口
    listen              5060;
    
    # SIP server ID(SIP服务器ID).
    # 设备端配置编号需要与该值一致,否则无法注册
    serial              34020000002000000001;

    # 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 ossrs/srs#307 (comment)
candidate $CANDIDATE;
}

vhost defaultVhost {
rtc {
enabled on;
bframe discard;
}

http_remux {
    enabled     on;
    mount       [vhost]/[app]/[stream].flv;
}

}

xxxxxxxxxxxx


**重现(Replay)**
 ./objs/srs -c conf/push.gb28181.conf 
> 重现Bug的步骤(How to replay bug?)
****
1. `xxxxxx`
1. `xxxxxx`
1. `xxxxxx`

**期望行为(Expect)**
成功连接设备
> 描述你期望发生的事情(Please describe your expectation)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant