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

requesting the HTTP-FLV using the HEAD method will cause a nullptr crash #4140

Closed
retamia opened this issue Aug 12, 2024 · 8 comments · Fixed by #4141
Closed

requesting the HTTP-FLV using the HEAD method will cause a nullptr crash #4140

retamia opened this issue Aug 12, 2024 · 8 comments · Fixed by #4141
Assignees

Comments

@retamia
Copy link
Contributor

retamia commented Aug 12, 2024

!!! Before submitting a new bug report, please ensure you have searched for any existing bugs and utilized
the Ask AI feature at https://ossrs.io or https://ossrs.net (for users in China). Duplicate issues or
questions that are overly simple or already addressed in the documentation will be removed without any
response.

Describe the bug

When there is a pull stream, if the push stream is disconnected, the subsequent push will always fail

SrsHttpStreamServer::hijack

Version
release6.0

To Reproduce
Steps to reproduce the behavior:

  1. OBS推流,ffplay 播放拉流(ffplay不要关闭)
  2. OBS断开推流,马上重新推流,会有概率性出现 Failed to handle HTTP request for pattern duplicated 错误。
    之后重新推流就会一直出现这个错误:Stream already exists or busy。

Expected behavior

Screenshots
image

Additional context

@retamia retamia closed this as completed Aug 12, 2024
@winlinvip
Copy link
Member

Why closed this issue?

@winlinvip winlinvip self-assigned this Aug 12, 2024
@winlinvip winlinvip reopened this Aug 12, 2024
@retamia
Copy link
Contributor Author

retamia commented Aug 12, 2024

Why closed this issue?

还没摸索出详细的复现步骤。目前是会出现在
serve error code=4001(HttpPatternDuplicated)(Failed to handle HTTP request for pattern duplicated) : process request=0 : cors serve : find handler : http hijack : http mount : http: mount flv stream for vhost=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e failed : pattern=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv exists | thread (28100)(0618674x): process_requests() (./src/app/srs_app_http_conn.cpp:208)(errno=35) << thread (28100)(0618674x): process_request() (./src/app/srs_app_http_conn.cpp:235)(errno=35) << thread (28100)(0618674x): serve_http() (./src/app/srs_app_http_conn.cpp:534)(errno=35) << thread (28100)(0618674x): find_handler() (./src/protocol/srs_protocol_http_stack.cpp:819)(errno=35) << thread (28100)(0618674x): hijack() (./src/app/srs_app_http_stream.cpp:1215)(errno=35) << thread (28100)(0618674x): http_mount() (./src/app/srs_app_http_stream.cpp:1045)(errno=35) << thread (28100)(0618674x): handle() (./src/protocol/srs_protocol_http_stack.cpp:698)(errno=35)(Resource temporarily unavailable)
这个错误日志之后。

排查代码是
streamHandlers[sid] = entry; 这里被新的entry覆盖
mux.handle(mount, entry->stream) 但是这里失败后,后续的请求会命中一个失败的streamHandlers[sid],导致crash
。我调换了下这两行代码顺序位置,flv请求不会crash了。

但是又碰到一个问题,后续重复推流会一直报错
serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy | thread (28100)(69x3190v): do_cycle() (./src/app/srs_app_rtmp_conn.cpp:271)(errno=2) << thread (28100)(69x3190v): service_cycle() (./src/app/srs_app_rtmp_conn.cpp:469)(errno=2) << thread (28100)(69x3190v): acquire_publish() (./src/app/srs_app_rtmp_conn.cpp:1206)(errno=2)

@winlinvip
Copy link
Member

Please use open source version of SRS to reproduce this issue, do not use modified version of SRS.

@retamia
Copy link
Contributor Author

retamia commented Aug 12, 2024

Please use open source version of SRS to reproduce this issue, do not use modified version of SRS.

release6.0分支

编译命令:
./configure --srt=on --rtc=off --jobs=12
make

复现步骤:

  1. OBS推流,ffplay 播放拉流(ffplay不要关闭)
  2. OBS断开推流,马上重新推流,会有概率性出现 Failed to handle HTTP request for pattern duplicated 错误。

之后重新推流就会一直出现这个错误:Stream already exists or busy。

完整日志:

./objs/srs -c conf/http.flv.live.conf


[2024-08-12 16:15:49.878][INFO][18516][0j294064] XCORE-SRS/6.0.145(Hang)
[2024-08-12 16:15:49.880][INFO][18516][0j294064] config parse complete
[2024-08-12 16:15:49.881][INFO][18516][0j294064] write log to console
[2024-08-12 16:15:49.881][INFO][18516][0j294064] SRS/6.0.145(Hang), MIT
[2024-08-12 16:15:49.881][INFO][18516][0j294064] authors: Winlin<[email protected]> XiaoZhihong<[email protected]> Winlin<[email protected]> ZhaoWenjie<[email protected]> ShiWei<[email protected]> XiaoZhihong<[email protected]> WuPengqiang<[email protected]> XiaLixin<[email protected]> LiPeng<[email protected]> ChenGuanghua<[email protected]> ChenHaibo<[email protected]> ZhangJunqin<[email protected]> and https://github.com/ossrs/srs/blob/develop/trunk/AUTHORS.md#contributors
[2024-08-12 16:15:49.881][INFO][18516][0j294064] cwd=/Volumes/t7/live/srs/trunk, work_dir=./, build: 2024-08-12 16:01:24, configure: --srt=on --rtc=off --jobs=12, uname: Darwin mtdeMacBook-Pro.local 23.5.0 Darwin Kernel Version 23.5.0: Wed May  1 20:09:52 PDT 2024; root:xnu-10063.121.3~5/RELEASE_X86_64 x86_64, osx: 1, env: 0, pkg: 
[2024-08-12 16:15:49.881][INFO][18516][0j294064] configure detail: --prefix=/usr/local/srs --config=conf/srs.conf --osx=on --hls=on --hds=off --dvr=on --ssl=on --https=on --ssl-1-0=off --ssl-local=off --sys-ssl=off --transcode=on --ingest=on --stat=on --http-callback=on --http-server=on --stream-converter=on --http-api=on --utest=off --srt=on --sys-srt=off --rtc=off --h265=on --gb28181=off --simulator=off --cxx11=on --cxx14=off --backtrace=on --ffmpeg-fit=reserved --sys-ffmpeg=off --ffmpeg-opus=off --nasm=on --srtp-nasm=off --sys-srtp=off --clean=on --gperf=off --gmc=off --gmd=off --gmp=off --gcp=off --gprof=off --static=off --shared-st=off --shared-srt=reserved --shared-ffmpeg=reserved --shared-srtp=reserved --log-verbose=off --log-info=off --log-trace=on --log-level_v2=on --gcov=off --apm=off --debug=off --debug-stats=off --cross-build=off --sanitizer=on --sanitizer-static=off --sanitizer-log=off --cygwin64=off --single-thread=on --generic-linux=off --build-cache=on --cc=gcc --cxx=g++ --ar=ar --ld=gcc --randlib=randlib
[2024-08-12 16:15:49.881][INFO][18516][0j294064] srs checking config...
[2024-08-12 16:15:49.882][INFO][18516][0j294064] ips, iface[0] en0 ipv4 0x8863 192.168.20.92, iface[1] en6 ipv4 0x8863 169.254.101.239, iface[2] en5 ipv6 0x8863 fe80::aede:48ff:fe00:1122%en5, iface[3] en0 ipv6 0x8863 fe80::8b2:73e:c5af:12d8%en0, iface[4] awdl0 ipv6 0x8843 fe80::a81e:21ff:feeb:735a%awdl0, iface[5] llw0 ipv6 0x8863 fe80::a81e:21ff:feeb:735a%llw0, iface[6] en6 ipv6 0x8863 fe80::1caf:b252:f848:686f%en6, iface[7] en14 ipv6 0x8863 fe80::68c0:a0ff:fef4:5333%en14
[2024-08-12 16:15:49.882][INFO][18516][0j294064] devices, intranet en0 192.168.20.92, internet en6 169.254.101.239, intranet en5 fe80::aede:48ff:fe00:1122%en5, intranet en0 fe80::8b2:73e:c5af:12d8%en0, intranet awdl0 fe80::a81e:21ff:feeb:735a%awdl0, intranet llw0 fe80::a81e:21ff:feeb:735a%llw0, intranet en6 fe80::1caf:b252:f848:686f%en6, intranet en14 fe80::68c0:a0ff:fef4:5333%en14
[2024-08-12 16:15:49.882][WARN][18516][0j294064][0] stats network use index=0, ip=192.168.20.92, ifname=en0
[2024-08-12 16:15:49.882][WARN][18516][0j294064][0] stats disk not configed, disk iops disabled.
[2024-08-12 16:15:49.882][INFO][18516][0j294064] write log to console
[2024-08-12 16:15:49.883][INFO][18516][0j294064] features, rch:on, dash:on, hls:on, hds:off, srt:on, hc:on, ha:on, hs:on, hp:on, dvr:on, trans:on, inge:on, stat:on, sc:on
[2024-08-12 16:15:49.883][INFO][18516][0j294064] SRS on amd64 x86_64, conf:conf/http.flv.live.conf, limit:1000, writev:1024, encoding:little-endian, HZ:100
[2024-08-12 16:15:49.883][INFO][18516][0j294064] mw sleep:350ms. mr enabled:on, default:0, sleep:350ms
[2024-08-12 16:15:49.883][INFO][18516][0j294064] gc:on, pq:30000ms, cscc:[0,16), csa:on, tn:on(may hurts performance), ss:auto(guess by merged write)
[2024-08-12 16:15:49.883][INFO][18516][0j294064] system default latency(ms): mw(0-350) + mr(0-350) + play-queue(0-30000)
[2024-08-12 16:15:49.883][WARN][18516][0j294064][0] SRS/6.0.145 is not stable
[2024-08-12 16:15:49.883][INFO][18516][0j294064] Run in single thread mode
[2024-08-12 16:15:49.890][INFO][18516][0j294064] CircuitBreaker: enabled=1, high=2x90, critical=1x95, dying=5x99
[2024-08-12 16:15:49.890][INFO][18516][0j294064] http flv live stream, vhost=__defaultVhost__, mount=[vhost]/[app]/[stream].flv
[2024-08-12 16:15:49.891][INFO][18516][0j294064] http: root mount to ./objs/nginx/html
[2024-08-12 16:15:49.891][INFO][18516][0j294064] server main cid=0j294064, pid=18516, ppid=19489, asprocess=0
[2024-08-12 16:15:49.891][INFO][18516][0j294064] RTMP listen at tcp://0.0.0.0:1935, fd=7
[2024-08-12 16:15:49.891][INFO][18516][0j294064] HTTP-Server listen at tcp://0.0.0.0:8080, fd=8
[2024-08-12 16:15:49.891][INFO][18516][0j294064] signal installed, reload=1, reopen=30, fast_quit=15, grace_quit=3
[2024-08-12 16:15:49.892][INFO][18516][0j294064] http: api mount /console to ./objs/nginx/html/console
[2024-08-12 16:15:49.892][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB
[2024-08-12 16:15:49.892][INFO][18516][98687sge] TCP: connection manager run, conns=0
[2024-08-12 16:15:49.892][INFO][18516][jf534z61] SRT: connection manager run, conns=0
[2024-08-12 16:15:54.878][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB
[2024-08-12 16:15:54.950][INFO][18516][4ce9073f] RTMP client ip=127.0.0.1:59846, fd=9
[2024-08-12 16:15:54.951][INFO][18516][4ce9073f] simple handshake success.
[2024-08-12 16:15:54.951][INFO][18516][4ce9073f] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:15:54.951][INFO][18516][4ce9073f] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:15:54.952][INFO][18516][4ce9073f] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:15:54.952][INFO][18516][4ce9073f] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:15:54.952][INFO][18516][4ce9073f] new live source, stream_url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e
[2024-08-12 16:15:54.953][INFO][18516][4ce9073f] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=/
[2024-08-12 16:15:54.953][INFO][18516][4ce9073f] ignore disabled exec for vhost=__defaultVhost__
[2024-08-12 16:15:54.953][INFO][18516][4ce9073f] http: mount flv stream for sid=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, mount=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv
[2024-08-12 16:15:54.954][INFO][18516][4ce9073f] start publish mr=0/350, p1stpt=20000, pnt=5000, tcp_nodelay=0
[2024-08-12 16:15:54.954][INFO][18516][4ce9073f] got metadata, width=1280, height=720, vcodec=7, acodec=10
[2024-08-12 16:15:55.118][INFO][18516][4ce9073f] 7B audio sh, codec(10, profile=LC, 2channels, 0kbps, 22050HZ), flv(16bits, 2channels, 22050HZ)
[2024-08-12 16:15:55.119][INFO][18516][4ce9073f] 50B video sh, codec(7, profile=Main, level=3.1, 1280x720, 0kbps, 0.0fps, 0.0s)
[2024-08-12 16:15:59.878][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB
[2024-08-12 16:16:01.116][INFO][18516][8b377c17] HTTP #0 127.0.0.1:59868 GET http://127.0.0.1:8080/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, content-length=-1
[2024-08-12 16:16:01.117][INFO][18516][8b377c17] dispatch cached gop success. count=4, duration=77
[2024-08-12 16:16:01.117][INFO][18516][8b377c17] create consumer, active=1, queue_size=30000ms, jitter=1
[2024-08-12 16:16:01.117][INFO][18516][8b377c17] FLV /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, encoder=FLV, mw_sleep=350ms, cache=0, msgs=128, dinm=1, guess_av=1/1/1
[2024-08-12 16:16:01.117][INFO][18516][8b377c17] FLV: write header audio=1, video=1, dinm=1, config=1/1/1
[2024-08-12 16:16:04.878][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=2,1, timer=62,0,0, clock=1,45,3,1,0,0,0,0,0
[2024-08-12 16:16:07.182][INFO][18516][4ce9073f] cleanup when unpublish
[2024-08-12 16:16:07.282][INFO][18516][8673cu43] RTMP client ip=127.0.0.1:59885, fd=11
[2024-08-12 16:16:07.282][INFO][18516][8673cu43] simple handshake success.
[2024-08-12 16:16:07.282][INFO][18516][8673cu43] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:16:07.282][INFO][18516][8673cu43] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:16:07.283][INFO][18516][8673cu43] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:16:07.283][INFO][18516][8673cu43] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:16:07.283][INFO][18516][8673cu43] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=/4ce9073f
[2024-08-12 16:16:07.283][INFO][18516][8673cu43] ignore disabled exec for vhost=__defaultVhost__
[2024-08-12 16:16:07.283][INFO][18516][8673cu43] TCP: before dispose resource(RtmpConn)(0x6120000013c0), conns=3, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:16:07.284][ERROR][18516][8673cu43][22] serve error code=4001(HttpPatternDuplicated)(Failed to handle HTTP request for pattern duplicated) : service cycle : rtmp: stream service : handle publish : http mount : http: mount flv stream for vhost=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e failed : pattern=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv exists
thread [18516][8673cu43]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=22]
thread [18516][8673cu43]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=22]
thread [18516][8673cu43]: on_publish() [./src/app/srs_app_source.cpp:2596][errno=22]
thread [18516][8673cu43]: on_publish() [./src/app/srs_app_server.cpp:1324][errno=22]
thread [18516][8673cu43]: http_mount() [./src/app/srs_app_http_stream.cpp:1035][errno=22]
thread [18516][8673cu43]: handle() [./src/protocol/srs_protocol_http_stack.cpp:698][errno=22](Invalid argument)
[2024-08-12 16:16:07.284][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=3, removing=0, unsubs=0
[2024-08-12 16:16:07.284][INFO][18516][8673cu43] TCP: disposing #0 resource(RtmpConn)(0x6120000013c0), conns=3, disposing=1, zombies=0
[2024-08-12 16:16:07.419][INFO][18516][8b377c17] TCP: before dispose resource(HttpConn)(0x60c000001d80), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:16:07.419][WARN][18516][8b377c17][4] server disconnect. ret=4040
[2024-08-12 16:16:07.419][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:16:07.420][INFO][18516][8b377c17] TCP: disposing #0 resource(HttpConn)(0x60c000001d80), conns=2, disposing=1, zombies=0
[2024-08-12 16:16:07.481][INFO][18516][4ce9073f] http: unmount flv stream for sid=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, i=3
[2024-08-12 16:16:07.482][INFO][18516][4ce9073f] TCP: before dispose resource(RtmpConn)(0x612000000640), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:16:07.482][WARN][18516][4ce9073f][4] client disconnect peer. ret=1009
[2024-08-12 16:16:07.482][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:16:07.482][INFO][18516][4ce9073f] TCP: disposing #0 resource(RtmpConn)(0x612000000640), conns=1, disposing=1, zombies=0
[2024-08-12 16:16:09.406][INFO][18516][196061g3] RTMP client ip=127.0.0.1:59890, fd=9
[2024-08-12 16:16:09.406][INFO][18516][196061g3] simple handshake success.
[2024-08-12 16:16:09.406][INFO][18516][196061g3] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:16:09.406][INFO][18516][196061g3] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:16:09.406][INFO][18516][196061g3] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:16:09.406][INFO][18516][196061g3] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:16:09.407][INFO][18516][196061g3] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=8673cu43/4ce9073f
[2024-08-12 16:16:09.407][INFO][18516][196061g3] TCP: before dispose resource(RtmpConn)(0x6120000016c0), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:16:09.407][ERROR][18516][196061g3][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [18516][196061g3]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [18516][196061g3]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [18516][196061g3]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:16:09.407][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:16:09.407][INFO][18516][196061g3] TCP: disposing #0 resource(RtmpConn)(0x6120000016c0), conns=1, disposing=1, zombies=0
[2024-08-12 16:16:09.879][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=2,1, timer=62,0,0, clock=1,45,3,1,0,0,0,0,0
[2024-08-12 16:16:14.879][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=8,2, timer=62,0,0, clock=0,46,2,0,0,0,1,0,0, free=1
[2024-08-12 16:16:19.879][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=8,2, timer=62,0,0, clock=0,46,2,0,0,0,1,0,0, free=1
[2024-08-12 16:16:24.880][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=8,2, timer=62,0,0, clock=0,46,2,0,0,0,1,0,0, free=1
[2024-08-12 16:16:29.880][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=62,0,0, clock=0,45,3,0,0,0,0,0,0
[2024-08-12 16:16:34.880][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=62,0,0, clock=0,45,3,0,0,0,0,0,0
[2024-08-12 16:16:39.881][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,44,3,0,0,0,0,1,0
[2024-08-12 16:16:43.385][INFO][18516][7ilh05m2] RTMP client ip=127.0.0.1:60134, fd=9
[2024-08-12 16:16:43.385][INFO][18516][7ilh05m2] simple handshake success.
[2024-08-12 16:16:43.385][INFO][18516][7ilh05m2] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:16:43.385][INFO][18516][7ilh05m2] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:16:43.386][INFO][18516][7ilh05m2] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:16:43.386][INFO][18516][7ilh05m2] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:16:43.386][INFO][18516][7ilh05m2] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=8673cu43/4ce9073f
[2024-08-12 16:16:43.386][INFO][18516][7ilh05m2] TCP: before dispose resource(RtmpConn)(0x6120000019c0), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:16:43.386][ERROR][18516][7ilh05m2][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [18516][7ilh05m2]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [18516][7ilh05m2]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [18516][7ilh05m2]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:16:43.386][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:16:43.386][INFO][18516][7ilh05m2] TCP: disposing #0 resource(RtmpConn)(0x6120000019c0), conns=1, disposing=1, zombies=0
[2024-08-12 16:16:44.881][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,44,3,0,0,0,0,1,0
[2024-08-12 16:16:47.502][INFO][18516][dp4478h0] HTTP #0 127.0.0.1:60145 GET http://127.0.0.1:8080/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, content-length=-1
[2024-08-12 16:16:47.502][INFO][18516][dp4478h0] http: mount flv stream for sid=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, mount=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv
[2024-08-12 16:16:47.502][INFO][18516][dp4478h0] flv: source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, is_edge=0, source_id=8673cu43/4ce9073f
[2024-08-12 16:16:47.502][INFO][18516][dp4478h0] dispatch cached gop success. count=0, duration=-1
[2024-08-12 16:16:47.502][INFO][18516][dp4478h0] create consumer, active=1, queue_size=30000ms, jitter=1
[2024-08-12 16:16:47.503][INFO][18516][dp4478h0] FLV /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, encoder=FLV, mw_sleep=350ms, cache=0, msgs=128, dinm=1, guess_av=1/1/1
[2024-08-12 16:16:49.881][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=3,1, timer=61,0,0, clock=0,43,4,0,0,0,0,1,0, free=1
[2024-08-12 16:16:51.006][INFO][18516][dp4478h0] TCP: before dispose resource(HttpConn)(0x60c0000040c0), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:16:51.006][WARN][18516][dp4478h0][54] client disconnect peer. ret=1007
[2024-08-12 16:16:51.006][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:16:51.006][INFO][18516][dp4478h0] TCP: disposing #0 resource(HttpConn)(0x60c0000040c0), conns=1, disposing=1, zombies=0
[2024-08-12 16:16:54.881][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=3,1, timer=61,0,0, clock=0,43,4,0,0,0,0,1,0, free=1
[2024-08-12 16:16:59.881][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=3,1, timer=61,0,0, clock=0,43,4,0,0,0,0,1,0, free=1
[2024-08-12 16:17:04.882][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,1, timer=62,0,0, clock=0,42,5,0,1,0,0,0,0, free=1
[2024-08-12 16:17:09.882][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,1, timer=62,0,0, clock=0,42,5,0,1,0,0,0,0, free=1
[2024-08-12 16:17:14.882][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,1, timer=62,0,0, clock=0,42,5,0,1,0,0,0,0, free=1
[2024-08-12 16:17:19.883][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,41,7,0,0,0,0,0,0
[2024-08-12 16:17:24.883][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,41,7,0,0,0,0,0,0
[2024-08-12 16:17:29.883][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,41,7,0,0,0,0,0,0
[2024-08-12 16:17:33.165][INFO][18516][r0698zd8] HTTP #0 127.0.0.1:60285 GET http://127.0.0.1:8080/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, content-length=-1
[2024-08-12 16:17:33.165][INFO][18516][r0698zd8] dispatch cached gop success. count=0, duration=-1
[2024-08-12 16:17:33.165][INFO][18516][r0698zd8] create consumer, active=1, queue_size=30000ms, jitter=1
[2024-08-12 16:17:33.165][INFO][18516][r0698zd8] FLV /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, encoder=FLV, mw_sleep=350ms, cache=0, msgs=128, dinm=1, guess_av=1/1/1
[2024-08-12 16:17:34.884][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,1, timer=61,0,0, clock=0,40,7,1,0,0,0,0,0
[2024-08-12 16:17:39.884][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,1, timer=61,0,0, clock=0,40,7,1,0,0,0,0,0
[2024-08-12 16:17:44.884][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,1, timer=61,0,0, clock=0,40,7,1,0,0,0,0,0
[2024-08-12 16:17:46.124][INFO][18516][r0698zd8] TCP: before dispose resource(HttpConn)(0x60c0000043c0), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:17:46.124][WARN][18516][r0698zd8][54] client disconnect peer. ret=1007
[2024-08-12 16:17:46.124][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:17:46.124][INFO][18516][r0698zd8] TCP: disposing #0 resource(HttpConn)(0x60c0000043c0), conns=1, disposing=1, zombies=0
[2024-08-12 16:17:49.145][INFO][18516][0y443sf9] RTMP client ip=127.0.0.1:60376, fd=9
[2024-08-12 16:17:49.146][INFO][18516][0y443sf9] simple handshake success.
[2024-08-12 16:17:49.146][INFO][18516][0y443sf9] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:17:49.146][INFO][18516][0y443sf9] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:17:49.146][INFO][18516][0y443sf9] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:17:49.146][INFO][18516][0y443sf9] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:17:49.146][INFO][18516][0y443sf9] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=8673cu43/4ce9073f
[2024-08-12 16:17:49.146][INFO][18516][0y443sf9] TCP: before dispose resource(RtmpConn)(0x612000001fc0), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:17:49.147][ERROR][18516][0y443sf9][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [18516][0y443sf9]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [18516][0y443sf9]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [18516][0y443sf9]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:17:49.147][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:17:49.147][INFO][18516][0y443sf9] TCP: disposing #0 resource(RtmpConn)(0x612000001fc0), conns=1, disposing=1, zombies=0
[2024-08-12 16:17:49.884][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=2,1, timer=61,0,0, clock=1,42,5,1,1,0,1,1,0, free=1
[2024-08-12 16:17:54.885][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=2,1, timer=61,0,0, clock=1,42,5,1,1,0,1,1,0, free=1
[2024-08-12 16:17:55.375][INFO][18516][71398607] HTTP #0 127.0.0.1:60389 GET http://127.0.0.1:8080/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, content-length=-1
[2024-08-12 16:17:55.375][INFO][18516][71398607] dispatch cached gop success. count=0, duration=-1
[2024-08-12 16:17:55.375][INFO][18516][71398607] create consumer, active=1, queue_size=30000ms, jitter=1
[2024-08-12 16:17:55.375][INFO][18516][71398607] FLV /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, encoder=FLV, mw_sleep=350ms, cache=0, msgs=128, dinm=1, guess_av=1/1/1
[2024-08-12 16:17:59.579][INFO][18516][71398607] TCP: before dispose resource(HttpConn)(0x60c000005080), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:17:59.579][WARN][18516][71398607][54] client disconnect peer. ret=1007
[2024-08-12 16:17:59.579][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:17:59.579][INFO][18516][71398607] TCP: disposing #0 resource(HttpConn)(0x60c000005080), conns=1, disposing=1, zombies=0
[2024-08-12 16:17:59.885][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=2,1, timer=61,0,0, clock=1,42,5,1,1,0,1,1,0, free=1
[2024-08-12 16:18:02.134][INFO][18516][65uq8643] RTMP client ip=127.0.0.1:60409, fd=9
[2024-08-12 16:18:02.135][INFO][18516][65uq8643] simple handshake success.
[2024-08-12 16:18:02.135][INFO][18516][65uq8643] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:18:02.135][INFO][18516][65uq8643] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:18:02.135][INFO][18516][65uq8643] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:18:02.135][INFO][18516][65uq8643] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:18:02.135][INFO][18516][65uq8643] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=8673cu43/4ce9073f
[2024-08-12 16:18:02.136][INFO][18516][65uq8643] TCP: before dispose resource(RtmpConn)(0x6120000028c0), conns=1, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:18:02.136][ERROR][18516][65uq8643][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [18516][65uq8643]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [18516][65uq8643]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [18516][65uq8643]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:18:02.136][INFO][18516][98687sge] TCP: clear zombies=1 resources, conns=1, removing=0, unsubs=0
[2024-08-12 16:18:02.136][INFO][18516][65uq8643] TCP: disposing #0 resource(RtmpConn)(0x6120000028c0), conns=1, disposing=1, zombies=0
[2024-08-12 16:18:04.885][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=3,1, timer=62,0,0, clock=0,44,4,1,1,0,1,0,0, free=1
[2024-08-12 16:18:09.886][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=3,1, timer=62,0,0, clock=0,44,4,1,1,0,1,0,0, free=1
[2024-08-12 16:18:14.886][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=62,0,0, clock=0,41,6,0,0,0,0,0,0
[2024-08-12 16:18:19.886][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=62,0,0, clock=0,41,6,0,0,0,0,0,0
[2024-08-12 16:18:24.886][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=62,0,0, clock=0,41,6,0,0,0,0,0,0
[2024-08-12 16:18:29.886][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,5,0,0,0,0,0,0
[2024-08-12 16:18:34.887][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,5,0,0,0,0,0,0
[2024-08-12 16:18:39.888][INFO][18516][n948ohj9] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,5,0,0,0,0,0,0
^C[2024-08-12 16:18:43.738][INFO][18516][0j294064] sig=2, user terminate program, fast quit
[2024-08-12 16:18:43.931][INFO][18516][0j294064] cleanup for quit signal fast=1, grace=0
[2024-08-12 16:18:43.931][WARN][18516][0j294064][35] main cycle terminated, system quit normally.
[2024-08-12 16:18:44.031][WARN][18516][0j294064][2] dispose unlink path failed. file=
[2024-08-12 16:18:44.031][INFO][18516][0j294064] gracefully dispose hls 
[2024-08-12 16:18:44.031][WARN][18516][0j294064][21] ignore remove mpd failed, /
[2024-08-12 16:18:44.031][INFO][18516][0j294064] gracefully dispose dash /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e
[2024-08-12 16:18:44.031][INFO][18516][0j294064] srs disposed
[2024-08-12 16:18:44.031][INFO][18516][0j294064] srs terminated
[2024-08-12 16:18:44.031][WARN][18516][0j294064][2] dispose unlink path failed. file=
[2024-08-12 16:18:44.031][INFO][18516][0j294064] gracefully dispose hls 
[2024-08-12 16:18:44.031][WARN][18516][0j294064][21] ignore remove mpd failed, /
[2024-08-12 16:18:44.031][INFO][18516][0j294064] gracefully dispose dash /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e
AddressSanitizer:DEADLYSIGNAL
=================================================================
==18516==ERROR: AddressSanitizer: SEGV on unknown address 0x000000000000 (pc 0x000109ce4d29 bp 0x7ff7b65fb510 sp 0x7ff7b65fb2e0 T0)
==18516==The signal is caused by a READ memory access.
==18516==Hint: address points to the zero page.
    #0 0x109ce4d29 in SrsLiveSource::on_unpublish() srs_app_source.cpp:2622
    #1 0x109ee5a5d in SrsEdgeIngester::stop() srs_app_edge.cpp:461
    #2 0x109ee4e0a in SrsEdgeIngester::~SrsEdgeIngester() srs_app_edge.cpp:408
    #3 0x109ee5104 in SrsEdgeIngester::~SrsEdgeIngester() srs_app_edge.cpp:407
    #4 0x109ee5128 in SrsEdgeIngester::~SrsEdgeIngester() srs_app_edge.cpp:407
    #5 0x109eeed23 in SrsPlayEdge::~SrsPlayEdge() srs_app_edge.cpp:967
    #6 0x109eeed84 in SrsPlayEdge::~SrsPlayEdge() srs_app_edge.cpp:966
    #7 0x109eeeda8 in SrsPlayEdge::~SrsPlayEdge() srs_app_edge.cpp:966
    #8 0x109cd7c96 in SrsLiveSource::~SrsLiveSource() srs_app_source.cpp:1923
    #9 0x109cd83d4 in SrsLiveSource::~SrsLiveSource() srs_app_source.cpp:1911
    #10 0x109cd83f8 in SrsLiveSource::~SrsLiveSource() srs_app_source.cpp:1911
    #11 0x109cb62d3 in SrsSharedPtr<SrsLiveSource>::reset() srs_core_autofree.hpp:152
    #12 0x109cb609f in SrsSharedPtr<SrsLiveSource>::~SrsSharedPtr() srs_core_autofree.hpp:143
    #13 0x109ca20f4 in SrsSharedPtr<SrsLiveSource>::~SrsSharedPtr() srs_core_autofree.hpp:142
    #14 0x109cfc2ac in std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>::~pair() pair.h:63
    #15 0x109cfc284 in std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>::~pair() pair.h:63
    #16 0x109cfc1e8 in void std::__1::allocator_traits<std::__1::allocator<std::__1::__tree_node<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, void*>>>::destroy[abi:v160006]<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>, void, void>(std::__1::allocator<std::__1::__tree_node<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, void*>>&, std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>*) allocator_traits.h:325
    #17 0x109cfc128 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>>>::destroy(std::__1::__tree_node<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, void*>*) __tree:1813
    #18 0x109cfc044 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>>>::~__tree() __tree:1801
    #19 0x109cfc014 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>>>::~__tree() __tree:1798
    #20 0x109cfbff4 in std::__1::map<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, std::__1::allocator<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>>>::~map[abi:v160006]() map:1164
    #21 0x109cd36e4 in std::__1::map<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, std::__1::allocator<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>>>::~map[abi:v160006]() map:1162
    #22 0x109cd388e in SrsLiveSourceManager::~SrsLiveSourceManager() srs_app_source.cpp:1762
    #23 0x109cd38c4 in SrsLiveSourceManager::~SrsLiveSourceManager() srs_app_source.cpp:1759
    #24 0x109cd38e8 in SrsLiveSourceManager::~SrsLiveSourceManager() srs_app_source.cpp:1759
    #25 0x109ff7503 in srs_global_dispose() srs_app_threads.cpp:462
    #26 0x10a0654fb in run_hybrid_server(void*) srs_main_server.cpp:530
    #27 0x10a065028 in run_in_thread_pool() srs_main_server.cpp:468
    #28 0x10a0646f7 in run_directly_or_daemon() srs_main_server.cpp:417
    #29 0x10a062149 in do_main(int, char**, char**) srs_main_server.cpp:245
    #30 0x10a064ce3 in main srs_main_server.cpp:256
    #31 0x7ff800223365 in start+0x795 (dyld:x86_64+0xfffffffffff5c365)

==18516==Register values:
rax = 0x0000000000000000  rbx = 0x00007ff7b65fb340  rcx = 0x0000100000000000  rdx = 0x0000000000000007  
rdi = 0x0000611000001800  rsi = 0x000000010ae840e0  rbp = 0x00007ff7b65fb510  rsp = 0x00007ff7b65fb2e0  
 r8 = 0x0000000000000028   r9 = 0x00007fffffffffff  r10 = 0x00007fffffffffff  r11 = 0x00000fffffffffff  
r12 = 0x00007ff7b65fc700  r13 = 0x0000000000000000  r14 = 0x000000010a064be0  r15 = 0x00007ff7b65fc880  
AddressSanitizer can not provide additional info.
SUMMARY: AddressSanitizer: SEGV srs_app_source.cpp:2622 in SrsLiveSource::on_unpublish()
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] =================================================================
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] ==18516==ERROR: AddressSanitizer: SEGV on unknown address 0x000000000000 (pc 0x000109ce4d29 bp 0x7ff7b65fb510 sp 0x7ff7b65fb2e0 T0)
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] ==18516==The signal is caused by a READ memory access.
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] ==18516==Hint: address points to the zero page.
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #0 0x109ce4d29 in SrsLiveSource::on_unpublish() srs_app_source.cpp:2622, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #1 0x109ee5a5d in SrsEdgeIngester::stop() srs_app_edge.cpp:461, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #2 0x109ee4e0a in SrsEdgeIngester::~SrsEdgeIngester() srs_app_edge.cpp:408, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #3 0x109ee5104 in SrsEdgeIngester::~SrsEdgeIngester() srs_app_edge.cpp:407, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #4 0x109ee5128 in SrsEdgeIngester::~SrsEdgeIngester() srs_app_edge.cpp:407, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #5 0x109eeed23 in SrsPlayEdge::~SrsPlayEdge() srs_app_edge.cpp:967, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #6 0x109eeed84 in SrsPlayEdge::~SrsPlayEdge() srs_app_edge.cpp:966, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #7 0x109eeeda8 in SrsPlayEdge::~SrsPlayEdge() srs_app_edge.cpp:966, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #8 0x109cd7c96 in SrsLiveSource::~SrsLiveSource() srs_app_source.cpp:1923, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #9 0x109cd83d4 in SrsLiveSource::~SrsLiveSource() srs_app_source.cpp:1911, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #10 0x109cd83f8 in SrsLiveSource::~SrsLiveSource() srs_app_source.cpp:1911, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #11 0x109cb62d3 in SrsSharedPtr<SrsLiveSource>::reset() srs_core_autofree.hpp:152, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #12 0x109cb609f in SrsSharedPtr<SrsLiveSource>::~SrsSharedPtr() srs_core_autofree.hpp:143, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #13 0x109ca20f4 in SrsSharedPtr<SrsLiveSource>::~SrsSharedPtr() srs_core_autofree.hpp:142, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #14 0x109cfc2ac in std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>::~pair() pair.h:63, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #15 0x109cfc284 in std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>::~pair() pair.h:63, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #16 0x109cfc1e8 in void std::__1::allocator_traits<std::__1::allocator<std::__1::__tree_node<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, void*>>>::destroy[abi:v160006]<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>, void, void>(std::__1::allocator<std::__1::__tree_node<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, void*>>&, std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>*) allocator_traits.h:325, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #17 0x109cfc128 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>>>::destroy(std::__1::__tree_node<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, void*>*) __tree:1813, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #18 0x109cfc044 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>>>::~__tree() __tree:1801, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #19 0x109cfc014 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>>>>::~__tree() __tree:1798, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #20 0x109cfbff4 in std::__1::map<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, std::__1::allocator<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>>>::~map[abi:v160006]() map:1164, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #21 0x109cd36e4 in std::__1::map<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsSharedPtr<SrsLiveSource>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, std::__1::allocator<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, SrsSharedPtr<SrsLiveSource>>>>::~map[abi:v160006]() map:1162, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #22 0x109cd388e in SrsLiveSourceManager::~SrsLiveSourceManager() srs_app_source.cpp:1762, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #23 0x109cd38c4 in SrsLiveSourceManager::~SrsLiveSourceManager() srs_app_source.cpp:1759, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #24 0x109cd38e8 in SrsLiveSourceManager::~SrsLiveSourceManager() srs_app_source.cpp:1759, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #25 0x109ff7503 in srs_global_dispose() srs_app_threads.cpp:462, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #26 0x10a0654fb in run_hybrid_server(void*) srs_main_server.cpp:530, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #27 0x10a065028 in run_in_thread_pool() srs_main_server.cpp:468, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #28 0x10a0646f7 in run_directly_or_daemon() srs_main_server.cpp:417, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #29 0x10a062149 in do_main(int, char**, char**) srs_main_server.cpp:245, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #30 0x10a064ce3 in main srs_main_server.cpp:256, r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]     #31 0x7ff800223365 in start+0x795 (dyld:x86_64+0xfffffffffff5c365), r0=1092
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] ==18516==Register values:
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] rax = 0x0000000000000000  rbx = 0x00007ff7b65fb340  rcx = 0x0000100000000000  rdx = 0x0000000000000007  
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] rdi = 0x0000611000001800  rsi = 0x000000010ae840e0  rbp = 0x00007ff7b65fb510  rsp = 0x00007ff7b65fb2e0  
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0]  r8 = 0x0000000000000028   r9 = 0x00007fffffffffff  r10 = 0x00007fffffffffff  r11 = 0x00000fffffffffff  
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] r12 = 0x00007ff7b65fc700  r13 = 0x0000000000000000  r14 = 0x000000010a064be0  r15 = 0x00007ff7b65fc880  
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] AddressSanitizer can not provide additional info.
[2024-08-12 16:18:44.357][ERROR][18516][0j294064][0] SUMMARY: AddressSanitizer: SEGV srs_app_source.cpp:2622 in SrsLiveSource::on_unpublish()
==18516==ABORTING
AddressSanitizer: nested bug in the same thread, aborting.```

@retamia
Copy link
Contributor Author

retamia commented Aug 12, 2024

这是另一次的日志。 断开马上重推后报错,之后ffplay重新拉流播放也会一直有错误日志出现

[2024-08-12 16:15:05.954][ERROR][92994][380zr631][35] serve error code=4001(HttpPatternDuplicated)(Failed to handle HTTP request for pattern duplicated) : process request=0 : cors serve : find handler : http hijack : http mount : http: mount flv stream for vhost=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e failed : pattern=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv exists
thread [92994][380zr631]: process_requests() [./src/app/srs_app_http_conn.cpp:208][errno=35]
thread [92994][380zr631]: process_request() [./src/app/srs_app_http_conn.cpp:235][errno=35]
thread [92994][380zr631]: serve_http() [./src/app/srs_app_http_conn.cpp:534][errno=35]
thread [92994][380zr631]: find_handler() [./src/protocol/srs_protocol_http_stack.cpp:819][errno=35]
thread [92994][380zr631]: hijack() [./src/app/srs_app_http_stream.cpp:1203][errno=35]
thread [92994][380zr631]: http_mount() [./src/app/srs_app_http_stream.cpp:1035][errno=35]
thread [92994][380zr631]: handle() [./src/protocol/srs_protocol_http_stack.cpp:698][errno=35](Resource temporarily unavailable)

这是详细的日志

[2024-08-12 16:13:31.271][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,4,1,1,0,1,0,0
[2024-08-12 16:13:32.156][INFO][92994][27811044] RTMP client ip=127.0.0.1:59220, fd=9
[2024-08-12 16:13:32.157][INFO][92994][27811044] simple handshake success.
[2024-08-12 16:13:32.157][INFO][92994][27811044] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:13:32.157][INFO][92994][27811044] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:13:32.157][INFO][92994][27811044] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:13:32.157][INFO][92994][27811044] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:13:32.157][INFO][92994][27811044] new live source, stream_url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e
[2024-08-12 16:13:32.158][INFO][92994][27811044] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=/
[2024-08-12 16:13:32.158][INFO][92994][27811044] ignore disabled exec for vhost=__defaultVhost__
[2024-08-12 16:13:32.158][INFO][92994][27811044] start publish mr=0/350, p1stpt=20000, pnt=5000, tcp_nodelay=0
[2024-08-12 16:13:32.159][INFO][92994][27811044] got metadata, width=1280, height=720, vcodec=7, acodec=10
[2024-08-12 16:13:32.339][INFO][92994][27811044] 7B audio sh, codec(10, profile=LC, 2channels, 0kbps, 22050HZ), flv(16bits, 2channels, 22050HZ)
[2024-08-12 16:13:32.339][INFO][92994][27811044] 50B video sh, codec(7, profile=Main, level=3.1, 1280x720, 0kbps, 0.0fps, 0.0s)
[2024-08-12 16:13:34.459][INFO][92994][06591168] HTTP #0 127.0.0.1:59228 GET http://127.0.0.1:8080/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, content-length=-1
[2024-08-12 16:13:34.459][INFO][92994][06591168] dispatch cached gop success. count=8, duration=144
[2024-08-12 16:13:34.459][INFO][92994][06591168] create consumer, active=1, queue_size=30000ms, jitter=1
[2024-08-12 16:13:34.459][INFO][92994][06591168] FLV /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, encoder=FLV, mw_sleep=350ms, cache=0, msgs=128, dinm=1, guess_av=1/1/1
[2024-08-12 16:13:34.459][INFO][92994][06591168] -> HTS http: got 11 msgs, age=0, min=8, mw=350
[2024-08-12 16:13:34.459][INFO][92994][06591168] FLV: write header audio=1, video=1, dinm=1, config=1/1/1
[2024-08-12 16:13:36.272][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,4,1,1,0,1,0,0
[2024-08-12 16:13:37.867][INFO][92994][27811044] cleanup when unpublish
[2024-08-12 16:13:37.962][INFO][92994][06591168] TCP: before dispose resource(HttpConn)(0x60c000015ac0), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:13:37.962][WARN][92994][06591168][4] server disconnect. ret=4040
[2024-08-12 16:13:37.962][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:13:37.962][INFO][92994][06591168] TCP: disposing #0 resource(HttpConn)(0x60c000015ac0), conns=2, disposing=1, zombies=0
[2024-08-12 16:13:38.070][INFO][92994][89qn5nyh] RTMP client ip=127.0.0.1:59238, fd=10
[2024-08-12 16:13:38.071][INFO][92994][89qn5nyh] simple handshake success.
[2024-08-12 16:13:38.071][INFO][92994][89qn5nyh] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:13:38.071][INFO][92994][89qn5nyh] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:13:38.071][INFO][92994][89qn5nyh] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:13:38.071][INFO][92994][89qn5nyh] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:13:38.071][INFO][92994][89qn5nyh] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=/27811044
[2024-08-12 16:13:38.072][INFO][92994][89qn5nyh] ignore disabled exec for vhost=__defaultVhost__
[2024-08-12 16:13:38.072][INFO][92994][89qn5nyh] TCP: before dispose resource(RtmpConn)(0x61200000b740), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:13:38.072][ERROR][92994][89qn5nyh][22] serve error code=4001(HttpPatternDuplicated)(Failed to handle HTTP request for pattern duplicated) : service cycle : rtmp: stream service : handle publish : http mount : http: mount flv stream for vhost=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e failed : pattern=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv exists
thread [92994][89qn5nyh]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=22]
thread [92994][89qn5nyh]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=22]
thread [92994][89qn5nyh]: on_publish() [./src/app/srs_app_source.cpp:2596][errno=22]
thread [92994][89qn5nyh]: on_publish() [./src/app/srs_app_server.cpp:1324][errno=22]
thread [92994][89qn5nyh]: http_mount() [./src/app/srs_app_http_stream.cpp:1035][errno=22]
thread [92994][89qn5nyh]: handle() [./src/protocol/srs_protocol_http_stack.cpp:698][errno=22](Invalid argument)
[2024-08-12 16:13:38.072][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:13:38.072][INFO][92994][89qn5nyh] TCP: disposing #0 resource(RtmpConn)(0x61200000b740), conns=2, disposing=1, zombies=0
[2024-08-12 16:13:40.007][INFO][92994][j5t1r2as] RTMP client ip=127.0.0.1:59249, fd=10
[2024-08-12 16:13:40.007][INFO][92994][j5t1r2as] simple handshake success.
[2024-08-12 16:13:40.008][INFO][92994][j5t1r2as] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:13:40.008][INFO][92994][j5t1r2as] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:13:40.008][INFO][92994][j5t1r2as] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:13:40.008][INFO][92994][j5t1r2as] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:13:40.008][INFO][92994][j5t1r2as] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=89qn5nyh/27811044
[2024-08-12 16:13:40.009][INFO][92994][j5t1r2as] TCP: before dispose resource(RtmpConn)(0x61200000bd40), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:13:40.009][ERROR][92994][j5t1r2as][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [92994][j5t1r2as]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [92994][j5t1r2as]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [92994][j5t1r2as]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:13:40.009][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:13:40.009][INFO][92994][j5t1r2as] TCP: disposing #0 resource(RtmpConn)(0x61200000bd40), conns=2, disposing=1, zombies=0
[2024-08-12 16:13:41.272][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=11,2, timer=62,0,0, clock=0,46,2,0,0,0,0,0,0, free=1
[2024-08-12 16:13:42.822][INFO][92994][68l471rc] RTMP client ip=127.0.0.1:59256, fd=10
[2024-08-12 16:13:42.823][INFO][92994][68l471rc] simple handshake success.
[2024-08-12 16:13:42.823][INFO][92994][68l471rc] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:13:42.823][INFO][92994][68l471rc] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:13:42.823][INFO][92994][68l471rc] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:13:42.823][INFO][92994][68l471rc] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:13:42.823][INFO][92994][68l471rc] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=89qn5nyh/27811044
[2024-08-12 16:13:42.824][INFO][92994][68l471rc] TCP: before dispose resource(RtmpConn)(0x6120000100c0), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:13:42.824][ERROR][92994][68l471rc][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [92994][68l471rc]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [92994][68l471rc]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [92994][68l471rc]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:13:42.824][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:13:42.824][INFO][92994][68l471rc] TCP: disposing #0 resource(RtmpConn)(0x6120000100c0), conns=2, disposing=1, zombies=0
[2024-08-12 16:13:46.273][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=11,2, timer=62,0,0, clock=0,46,2,0,0,0,0,0,0, free=1
[2024-08-12 16:13:50.240][INFO][92994][z402d126] RTMP client ip=127.0.0.1:59338, fd=10
[2024-08-12 16:13:50.241][INFO][92994][z402d126] simple handshake success.
[2024-08-12 16:13:50.241][INFO][92994][z402d126] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:13:50.241][INFO][92994][z402d126] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:13:50.242][INFO][92994][z402d126] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:13:50.242][INFO][92994][z402d126] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:13:50.242][INFO][92994][z402d126] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=89qn5nyh/27811044
[2024-08-12 16:13:50.242][INFO][92994][z402d126] TCP: before dispose resource(RtmpConn)(0x6120000106c0), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:13:50.242][ERROR][92994][z402d126][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [92994][z402d126]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [92994][z402d126]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [92994][z402d126]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:13:50.242][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:13:50.242][INFO][92994][z402d126] TCP: disposing #0 resource(RtmpConn)(0x6120000106c0), conns=2, disposing=1, zombies=0
[2024-08-12 16:13:51.273][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=4,1, timer=62,0,0, clock=0,46,2,0,0,0,0,0,0, free=1
[2024-08-12 16:13:56.274][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=4,1, timer=62,0,0, clock=0,46,2,0,0,0,0,0,0, free=1
[2024-08-12 16:14:01.274][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,44,4,0,0,0,1,0,0
[2024-08-12 16:14:05.886][INFO][92994][5u9q8j2d] RTMP client ip=127.0.0.1:59483, fd=10
[2024-08-12 16:14:05.887][INFO][92994][5u9q8j2d] simple handshake success.
[2024-08-12 16:14:05.887][INFO][92994][5u9q8j2d] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:14:05.887][INFO][92994][5u9q8j2d] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:14:05.888][INFO][92994][5u9q8j2d] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:14:05.888][INFO][92994][5u9q8j2d] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:14:05.888][INFO][92994][5u9q8j2d] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=89qn5nyh/27811044
[2024-08-12 16:14:05.888][INFO][92994][5u9q8j2d] TCP: before dispose resource(RtmpConn)(0x612000010840), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:14:05.888][ERROR][92994][5u9q8j2d][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [92994][5u9q8j2d]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [92994][5u9q8j2d]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [92994][5u9q8j2d]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:14:05.888][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:14:05.888][INFO][92994][5u9q8j2d] TCP: disposing #0 resource(RtmpConn)(0x612000010840), conns=2, disposing=1, zombies=0
[2024-08-12 16:14:06.274][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,44,4,0,0,0,1,0,0
[2024-08-12 16:14:11.274][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=2,1, timer=61,0,0, clock=0,46,2,1,0,0,1,0,0, free=1
[2024-08-12 16:14:13.926][INFO][92994][454z9j76] RTMP client ip=127.0.0.1:59502, fd=10
[2024-08-12 16:14:13.927][INFO][92994][454z9j76] simple handshake success.
[2024-08-12 16:14:13.927][INFO][92994][454z9j76] connect app, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=127.0.0.1, port=1935, app=live, args=null
[2024-08-12 16:14:13.927][INFO][92994][454z9j76] protocol in.buffer=0, in.ack=0, out.ack=0, in.chunk=4096, out.chunk=128
[2024-08-12 16:14:13.927][INFO][92994][454z9j76] client identified, type=fmle-publish, vhost=127.0.0.1, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, duration=0ms
[2024-08-12 16:14:13.927][INFO][92994][454z9j76] connected stream, tcUrl=rtmp://127.0.0.1:1935/live, pageUrl=, swfUrl=rtmp://127.0.0.1:1935/live, schema=rtmp, vhost=__defaultVhost__, port=1935, app=live, stream=202404-78db246b-9ad8-472b-9dd6-df04f108886e, param=, args=null
[2024-08-12 16:14:13.927][INFO][92994][454z9j76] source url=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e, ip=127.0.0.1, cache=1/2500, is_edge=0, source_id=89qn5nyh/27811044
[2024-08-12 16:14:13.928][INFO][92994][454z9j76] TCP: before dispose resource(RtmpConn)(0x612000010b40), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:14:13.928][ERROR][92994][454z9j76][35] serve error code=1028(StreamBusy)(Stream already exists or busy) : service cycle : rtmp: stream service : rtmp: stream /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e is busy
thread [92994][454z9j76]: do_cycle() [./src/app/srs_app_rtmp_conn.cpp:263][errno=35]
thread [92994][454z9j76]: service_cycle() [./src/app/srs_app_rtmp_conn.cpp:457][errno=35]
thread [92994][454z9j76]: acquire_publish() [./src/app/srs_app_rtmp_conn.cpp:1078][errno=35](Resource temporarily unavailable)
[2024-08-12 16:14:13.928][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:14:13.928][INFO][92994][454z9j76] TCP: disposing #0 resource(RtmpConn)(0x612000010b40), conns=2, disposing=1, zombies=0
[2024-08-12 16:14:16.274][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=2,1, timer=61,0,0, clock=0,46,2,1,0,0,1,0,0, free=1
[2024-08-12 16:14:21.275][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=2,1, timer=61,0,0, clock=0,46,2,1,0,0,1,0,0, free=1
[2024-08-12 16:14:26.276][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,1, timer=62,0,0, clock=0,43,5,0,0,0,0,0,0, free=1
[2024-08-12 16:14:31.276][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,1, timer=62,0,0, clock=0,43,5,0,0,0,0,0,0, free=1
[2024-08-12 16:14:36.276][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=62,0,0, clock=0,43,5,1,1,0,0,0,0
[2024-08-12 16:14:41.277][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=62,0,0, clock=0,43,5,1,1,0,0,0,0
[2024-08-12 16:14:46.277][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,41,6,1,0,0,0,0,0
[2024-08-12 16:14:51.277][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,41,6,1,0,0,0,0,0
[2024-08-12 16:14:56.278][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,41,6,1,0,0,0,0,0
[2024-08-12 16:15:01.278][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,4,1,0,1,0,0,0
[2024-08-12 16:15:05.954][INFO][92994][380zr631] HTTP #0 127.0.0.1:59689 GET http://127.0.0.1:8080/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv, content-length=-1
[2024-08-12 16:15:05.954][INFO][92994][380zr631] TCP: before dispose resource(HttpConn)(0x60c000019c00), conns=2, zombies=0, ign=0, inz=0, ind=0
[2024-08-12 16:15:05.954][ERROR][92994][380zr631][35] serve error code=4001(HttpPatternDuplicated)(Failed to handle HTTP request for pattern duplicated) : process request=0 : cors serve : find handler : http hijack : http mount : http: mount flv stream for vhost=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e failed : pattern=/live/202404-78db246b-9ad8-472b-9dd6-df04f108886e.flv exists
thread [92994][380zr631]: process_requests() [./src/app/srs_app_http_conn.cpp:208][errno=35]
thread [92994][380zr631]: process_request() [./src/app/srs_app_http_conn.cpp:235][errno=35]
thread [92994][380zr631]: serve_http() [./src/app/srs_app_http_conn.cpp:534][errno=35]
thread [92994][380zr631]: find_handler() [./src/protocol/srs_protocol_http_stack.cpp:819][errno=35]
thread [92994][380zr631]: hijack() [./src/app/srs_app_http_stream.cpp:1203][errno=35]
thread [92994][380zr631]: http_mount() [./src/app/srs_app_http_stream.cpp:1035][errno=35]
thread [92994][380zr631]: handle() [./src/protocol/srs_protocol_http_stack.cpp:698][errno=35](Resource temporarily unavailable)
[2024-08-12 16:15:05.954][INFO][92994][9ie6y0pu] TCP: clear zombies=1 resources, conns=2, removing=0, unsubs=0
[2024-08-12 16:15:05.954][INFO][92994][380zr631] TCP: disposing #0 resource(HttpConn)(0x60c000019c00), conns=2, disposing=1, zombies=0
[2024-08-12 16:15:06.278][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,4,1,0,1,0,0,0
[2024-08-12 16:15:11.279][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,0, timer=61,0,0, clock=0,43,4,1,0,1,0,0,0
[2024-08-12 16:15:16.279][INFO][92994][1z371o70] Hybrid cpu=0.00%,0MB, cid=1,1, timer=61,0,0, clock=0,42,6,0,0,0,1,0,0, free=1
^C[2024-08-12 16:15:18.486][INFO][92994][d15z3x26] sig=2, user terminate program, fast quit
[2024-08-12 16:15:19.485][INFO][92994][d15z3x26] cleanup for quit signal fast=1, grace=0
[2024-08-12 16:15:19.485][WARN][92994][d15z3x26][35] main cycle terminated, system quit normally.
[2024-08-12 16:15:19.585][WARN][92994][d15z3x26][2] dispose unlink path failed. file=
[2024-08-12 16:15:19.585][INFO][92994][d15z3x26] gracefully dispose hls 
[2024-08-12 16:15:19.585][WARN][92994][d15z3x26][21] ignore remove mpd failed, /
[2024-08-12 16:15:19.585][INFO][92994][d15z3x26] gracefully dispose dash /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e
[2024-08-12 16:15:19.585][INFO][92994][d15z3x26] srs disposed
[2024-08-12 16:15:19.585][INFO][92994][d15z3x26] srs terminated
[2024-08-12 16:15:19.585][WARN][92994][d15z3x26][2] dispose unlink path failed. file=
[2024-08-12 16:15:19.585][INFO][92994][d15z3x26] gracefully dispose hls 
[2024-08-12 16:15:19.586][WARN][92994][d15z3x26][21] ignore remove mpd failed, /
[2024-08-12 16:15:19.586][INFO][92994][d15z3x26] gracefully dispose dash /live/202404-78db246b-9ad8-472b-9dd6-df04f108886e
=================================================================
==92994==ERROR: AddressSanitizer: heap-use-after-free on address 0x60e000000150 at pc 0x00010b4bac6c bp 0x0001113c45d0 sp 0x0001113c45c8
READ of size 8 at 0x60e000000150 thread T0
    #0 0x10b4bac6b in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>>>::__root[abi:v160006]() const __tree:1101

0x60e000000150 is located 48 bytes inside of 160-byte region [0x60e000000120,0x60e0000001c0)
freed by thread T0 here:
    #0 0x10cd30a2d in wrap__ZdlPv+0x7d (libclang_rt.asan_osx_dynamic.dylib:x86_64h+0xeca2d)
    #1 0x10b640e61 in SrsHttpStreamServer::~SrsHttpStreamServer() srs_app_http_stream.cpp:954
    #2 0x10b789773 in SrsHttpServer::~SrsHttpServer() srs_app_http_conn.cpp:486
    #3 0x10b7898c4 in SrsHttpServer::~SrsHttpServer() srs_app_http_conn.cpp:485
    #4 0x10b7898e8 in SrsHttpServer::~SrsHttpServer() srs_app_http_conn.cpp:485
    #5 0x10b543e92 in SrsServer::destroy() srs_app_server.cpp:382
    #6 0x10b543837 in SrsServer::~SrsServer() srs_app_server.cpp:368
    #7 0x10b5438b4 in SrsServer::~SrsServer() srs_app_server.cpp:367
    #8 0x10b543978 in SrsServer::~SrsServer() srs_app_server.cpp:367
    #9 0x10b5553a3 in SrsServerAdapter::~SrsServerAdapter() srs_app_server.cpp:1350
    #10 0x10b555404 in SrsServerAdapter::~SrsServerAdapter() srs_app_server.cpp:1349
    #11 0x10b555428 in SrsServerAdapter::~SrsServerAdapter() srs_app_server.cpp:1349
    #12 0x10b8ddae3 in SrsHybridServer::~SrsHybridServer() srs_app_hybrid.cpp:143
    #13 0x10b8de5f4 in SrsHybridServer::~SrsHybridServer() srs_app_hybrid.cpp:138
    #14 0x10b8de618 in SrsHybridServer::~SrsHybridServer() srs_app_hybrid.cpp:138
    #15 0x10b8ec418 in srs_global_dispose() srs_app_threads.cpp:461
    #16 0x10b95a4fb in run_hybrid_server(void*) srs_main_server.cpp:530
    #17 0x10b95a028 in run_in_thread_pool() srs_main_server.cpp:468
    #18 0x10b9596f7 in run_directly_or_daemon() srs_main_server.cpp:417
    #19 0x10b957149 in do_main(int, char**, char**) srs_main_server.cpp:245
    #20 0x10b959ce3 in main srs_main_server.cpp:256
    #21 0x7ff800223365 in start+0x795 (dyld:x86_64+0xfffffffffff5c365)

previously allocated by thread T0 here:
    #0 0x10cd3060d in wrap__Znwm+0x7d (libclang_rt.asan_osx_dynamic.dylib:x86_64h+0xec60d)
    #1 0x10b789531 in SrsHttpServer::SrsHttpServer(SrsServer*) srs_app_http_conn.cpp:480
    #2 0x10b78966c in SrsHttpServer::SrsHttpServer(SrsServer*) srs_app_http_conn.cpp:478
    #3 0x10b542d2a in SrsServer::SrsServer() srs_app_server.cpp:355
    #4 0x10b543644 in SrsServer::SrsServer() srs_app_server.cpp:325
    #5 0x10b55520b in SrsServerAdapter::SrsServerAdapter() srs_app_server.cpp:1345
    #6 0x10b5552a4 in SrsServerAdapter::SrsServerAdapter() srs_app_server.cpp:1344
    #7 0x10b95a09c in run_hybrid_server(void*) srs_main_server.cpp:494
    #8 0x10b95a028 in run_in_thread_pool() srs_main_server.cpp:468
    #9 0x10b9596f7 in run_directly_or_daemon() srs_main_server.cpp:417
    #10 0x10b957149 in do_main(int, char**, char**) srs_main_server.cpp:245
    #11 0x10b959ce3 in main srs_main_server.cpp:256
    #12 0x7ff800223365 in start+0x795 (dyld:x86_64+0xfffffffffff5c365)

SUMMARY: AddressSanitizer: heap-use-after-free __tree:1101 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>>>::__root[abi:v160006]() const
Shadow bytes around the buggy address:
  0x60dffffffe80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x60dfffffff00: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x60dfffffff80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x60e000000000: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
  0x60e000000080: fd fd fd fd fd fd fd fd fd fd fd fd fa fa fa fa
=>0x60e000000100: fa fa fa fa fd fd fd fd fd fd[fd]fd fd fd fd fd
  0x60e000000180: fd fd fd fd fd fd fd fd fa fa fa fa fa fa fa fa
  0x60e000000200: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x60e000000280: 00 00 00 00 fa fa fa fa fa fa fa fa 00 00 00 00
  0x60e000000300: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
  0x60e000000380: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
Shadow byte legend (one shadow byte represents 8 application bytes):
  Addressable:           00
  Partially addressable: 01 02 03 04 05 06 07 
  Heap left redzone:       fa
  Freed heap region:       fd
  Stack left redzone:      f1
  Stack mid redzone:       f2
  Stack right redzone:     f3
  Stack after return:      f5
  Stack use after scope:   f8
  Global redzone:          f9
  Global init order:       f6
  Poisoned by user:        f7
  Container overflow:      fc
  Array cookie:            ac
  Intra object redzone:    bb
  ASan internal:           fe
  Left alloca redzone:     ca
  Right alloca redzone:    cb
[2024-08-12 16:15:21.039][ERROR][92994][27811044][0] =================================================================
[2024-08-12 16:15:21.039][ERROR][92994][27811044][0] ==92994==ERROR: AddressSanitizer: heap-use-after-free on address 0x60e000000150 at pc 0x00010b4bac6c bp 0x0001113c45d0 sp 0x0001113c45c8
[2024-08-12 16:15:21.039][ERROR][92994][27811044][0] READ of size 8 at 0x60e000000150 thread T0
[2024-08-12 16:15:21.039][ERROR][92994][27811044][0]     #0 0x10b4bac6b in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>>>::__root[abi:v160006]() const __tree:1101, r0=1092
[2024-08-12 16:15:21.039][ERROR][92994][27811044][0] 0x60e000000150 is located 48 bytes inside of 160-byte region [0x60e000000120,0x60e0000001c0)
[2024-08-12 16:15:21.039][ERROR][92994][27811044][0] freed by thread T0 here:
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #0 0x10cd30a2d in wrap__ZdlPv+0x7d (libclang_rt.asan_osx_dynamic.dylib:x86_64h+0xeca2d), r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #1 0x10b640e61 in SrsHttpStreamServer::~SrsHttpStreamServer() srs_app_http_stream.cpp:954, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #2 0x10b789773 in SrsHttpServer::~SrsHttpServer() srs_app_http_conn.cpp:486, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #3 0x10b7898c4 in SrsHttpServer::~SrsHttpServer() srs_app_http_conn.cpp:485, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #4 0x10b7898e8 in SrsHttpServer::~SrsHttpServer() srs_app_http_conn.cpp:485, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #5 0x10b543e92 in SrsServer::destroy() srs_app_server.cpp:382, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #6 0x10b543837 in SrsServer::~SrsServer() srs_app_server.cpp:368, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #7 0x10b5438b4 in SrsServer::~SrsServer() srs_app_server.cpp:367, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #8 0x10b543978 in SrsServer::~SrsServer() srs_app_server.cpp:367, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #9 0x10b5553a3 in SrsServerAdapter::~SrsServerAdapter() srs_app_server.cpp:1350, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #10 0x10b555404 in SrsServerAdapter::~SrsServerAdapter() srs_app_server.cpp:1349, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #11 0x10b555428 in SrsServerAdapter::~SrsServerAdapter() srs_app_server.cpp:1349, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #12 0x10b8ddae3 in SrsHybridServer::~SrsHybridServer() srs_app_hybrid.cpp:143, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #13 0x10b8de5f4 in SrsHybridServer::~SrsHybridServer() srs_app_hybrid.cpp:138, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #14 0x10b8de618 in SrsHybridServer::~SrsHybridServer() srs_app_hybrid.cpp:138, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #15 0x10b8ec418 in srs_global_dispose() srs_app_threads.cpp:461, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #16 0x10b95a4fb in run_hybrid_server(void*) srs_main_server.cpp:530, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #17 0x10b95a028 in run_in_thread_pool() srs_main_server.cpp:468, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #18 0x10b9596f7 in run_directly_or_daemon() srs_main_server.cpp:417, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #19 0x10b957149 in do_main(int, char**, char**) srs_main_server.cpp:245, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #20 0x10b959ce3 in main srs_main_server.cpp:256, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #21 0x7ff800223365 in start+0x795 (dyld:x86_64+0xfffffffffff5c365), r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0] previously allocated by thread T0 here:
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #0 0x10cd3060d in wrap__Znwm+0x7d (libclang_rt.asan_osx_dynamic.dylib:x86_64h+0xec60d), r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #1 0x10b789531 in SrsHttpServer::SrsHttpServer(SrsServer*) srs_app_http_conn.cpp:480, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #2 0x10b78966c in SrsHttpServer::SrsHttpServer(SrsServer*) srs_app_http_conn.cpp:478, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #3 0x10b542d2a in SrsServer::SrsServer() srs_app_server.cpp:355, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #4 0x10b543644 in SrsServer::SrsServer() srs_app_server.cpp:325, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #5 0x10b55520b in SrsServerAdapter::SrsServerAdapter() srs_app_server.cpp:1345, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #6 0x10b5552a4 in SrsServerAdapter::SrsServerAdapter() srs_app_server.cpp:1344, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #7 0x10b95a09c in run_hybrid_server(void*) srs_main_server.cpp:494, r0=1092
[2024-08-12 16:15:21.040][ERROR][92994][27811044][0]     #8 0x10b95a028 in run_in_thread_pool() srs_main_server.cpp:468, r0=1092
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]     #9 0x10b9596f7 in run_directly_or_daemon() srs_main_server.cpp:417, r0=1092
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]     #10 0x10b957149 in do_main(int, char**, char**) srs_main_server.cpp:245, r0=1092
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]     #11 0x10b959ce3 in main srs_main_server.cpp:256, r0=1092
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]     #12 0x7ff800223365 in start+0x795 (dyld:x86_64+0xfffffffffff5c365), r0=1092
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0] SUMMARY: AddressSanitizer: heap-use-after-free __tree:1101 in std::__1::__tree<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::__map_value_compare<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>, std::__1::less<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, true>, std::__1::allocator<std::__1::__value_type<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, SrsHttpMuxEntry*>>>::__root[abi:v160006]() const
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0] Shadow bytes around the buggy address:
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60dffffffe80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60dfffffff00: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60dfffffff80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60e000000000: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60e000000080: fd fd fd fd fd fd fd fd fd fd fd fd fa fa fa fa
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0] =>0x60e000000100: fa fa fa fa fd fd fd fd fd fd[fd]fd fd fd fd fd
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60e000000180: fd fd fd fd fd fd fd fd fa fa fa fa fa fa fa fa
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60e000000200: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60e000000280: 00 00 00 00 fa fa fa fa fa fa fa fa 00 00 00 00
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60e000000300: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   0x60e000000380: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0] Shadow byte legend (one shadow byte represents 8 application bytes):
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Addressable:           00
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Partially addressable: 01 02 03 04 05 06 07 
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Heap left redzone:       fa
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Freed heap region:       fd
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Stack left redzone:      f1
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Stack mid redzone:       f2
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Stack right redzone:     f3
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Stack after return:      f5
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Stack use after scope:   f8
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Global redzone:          f9
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Global init order:       f6
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Poisoned by user:        f7
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Container overflow:      fc
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Array cookie:            ac
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Intra object redzone:    bb
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   ASan internal:           fe
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Left alloca redzone:     ca
[2024-08-12 16:15:21.041][ERROR][92994][27811044][0]   Right alloca redzone:    cb
==92994==ABORTING
AddressSanitizer: nested bug in the same thread, aborting.

@retamia
Copy link
Contributor Author

retamia commented Aug 12, 2024

看着跟 #4103 这个issue有点类似。

cleanup when unpublish 后没有调用unmount,重新推流调用mount失败,_can_publish一直是false,导致这条流后续就无法重新推流了

@retamia
Copy link
Contributor Author

retamia commented Aug 12, 2024

简单改了下代码,没有详细测试,暂时没出现这个问题了
SrsLiveSource::on_unpublish()_can_publish = true;挪到了函数最后

@@ -2633,7 +2633,6 @@ void SrsLiveSource::on_unpublish()
 
     srs_trace("cleanup when unpublish");
     
-    _can_publish = true;
     if (!_source_id.empty()) {
         _pre_source_id = _source_id;
     }
@@ -2655,6 +2654,8 @@ void SrsLiveSource::on_unpublish()
     if (consumers.empty()) {
         stream_die_at_ = srs_get_system_time();
     }
+
+    _can_publish = true;
 }

@winlinvip
Copy link
Member

winlinvip commented Aug 12, 2024

Make sense. I think it should be caused by the handler callback that will stop the coroutine:

    _can_publish = true;
    handler->on_unpublish(req);

In this handler, the http_unmount will be called:

void SrsHttpStreamServer::http_unmount(SrsRequest* r)
    cache->stop();

In this http_unmount function, there should be context switching.

Please file an PullRequest to fix this issue. Thanks.

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

Successfully merging a pull request may close this issue.

2 participants