go2rtc: go2rtc does not recover connection to camera unless I restart go2rtc
I have a chinese ICSee/dvrip camera, which works great, including 2-way audio.
However, there is a problem: sometimes go2rtc loses the connection to it and it does not recover automatically, unless I manually restart go2rtc.
Camera is connected through Wi-Fi.
I am using go2rtc 1.8.3.
I have even built a Home Assistant automation to help me circumvent this problem:
# configuration.yaml
rest_command:
restart_go2rtc:
method: POST
url: "http://ccab4aaf-frigate-beta:1984/api/restart"
automations:
alias: Restart go2rtc when camera da rua becomes unavailable
trigger:
- platform: state
entity_id:
- camera.rua
to: unavailable
for:
seconds: 10
condition:
- condition: state
entity_id: sensor.frigate_status
state: running
action:
- service: rest_command.restart_go2rtc
mode: single
My go2rtc config is:
go2rtc:
streams:
rua_h265:
- rtsp://192.168.1.21/user=tema_password=pass_channel=0_stream=1&onvif=0.sdp?real_stream
- ffmpeg:rua_h265#audio=aac
rua:
- ffmpeg:rua_h265#video=h264#hardware=vaapi
- rtsp://127.0.0.1:8554/rua_h265?audio=all
- dvrip://tema:pass@192.168.1.21:34567?backchannel=1
rua_hd:
# This stream is H265
- rtsp://192.168.1.21/user=tema_password=pass_channel=0_stream=0&onvif=0.sdp?real_stream#media=video
- rtsp://127.0.0.1:8554/rua_h265?audio=all
And I see these errors in my go2rtc logs:
2023-11-18 15:36:14.293907617 12:36:14.293 WRN [streams] json locked
2023-11-18 15:36:14.293910867 12:36:14.293 WRN [streams] json locked
2023-11-18 15:36:15.303973943 12:36:15.303 WRN [rtsp] error="streams: codecs not matched: H265, PCMA => AAC" stream=rua_h265
2023-11-18 15:36:15.305847379 12:36:15.305 WRN github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:225 > error="write tcp 127.0.0.1:8554->127.0.0.1:55914: write: broken pipe"
2023-11-18 15:36:35.818477295 12:36:35.818 WRN [rtsp] error="streams: codecs not matched: H265, PCMA => AAC" stream=rua_h265
2023-11-18 15:36:35.818646938 12:36:35.818 WRN github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:225 > error="write tcp 127.0.0.1:8554->127.0.0.1:39774: write: broken pipe"
2023-11-18 15:36:44.304954211 12:36:44.304 WRN [streams] json locked
2023-11-18 15:36:44.304969397 12:36:44.304 WRN [streams] json locked
2023-11-18 15:36:56.400898335 12:36:56.400 WRN [rtsp] error="streams: codecs not matched: H265, PCMA => AAC" stream=rua_h265
2023-11-18 15:36:56.401023228 12:36:56.400 WRN github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:225 > error="write tcp 127.0.0.1:8554->127.0.0.1:51050: write: broken pipe"
2023-11-18 15:37:14.331881702 12:37:14.320 WRN [streams] json locked
2023-11-18 15:37:14.331884919 12:37:14.320 WRN [streams] json locked
2023-11-18 15:37:37.485948322 12:37:37.485 WRN [rtsp] error="streams: codecs not matched: H265, PCMA => AAC" stream=rua_h265
If I scroll up for a while, I can also see:
url=rtsp://192.168.1.21/user=tema_password=pass_channel=0_stream=0&onvif=0.sdp?real_stream#media=video
2023-11-18 11:10:46.636306286 08:10:46.636 WRN github.com/AlexxIT/go2rtc/internal/streams/producer.go:171 > error="read tcp 172.30.33.6:37798->192.168.1.21:554: i/o timeout" url=rtsp://192.168.1.21/user=tema_password=pass_channel=0_stream=1&onvif=0.sdp?real_stream
2023-11-18 11:10:51.176080719 08:10:51.175 WRN github.com/AlexxIT/go2rtc/internal/streams/producer.go:171 > error="read tcp 172.30.33.6:34792->192.168.1.21:554: i/o timeout" url=rtsp://192.168.1.21/user=tema_password=pass_channel=0_stream=0&onvif=0.sdp?real_stream#media=video
2023-11-18 11:11:03.115253089 08:11:03.115 WRN [streams] json locked
2023-11-18 11:11:10.878418990 08:11:10.875 WRN [rtsp] error="streams: codecs not matched: H265, PCMA => AAC" stream=rua_h265
And if I scroll up a lot I can find this:
Click here to show
2023-11-17 21:28:18.557372174 goroutine 280714 [IO wait]:
2023-11-17 21:28:18.557372981 internal/poll.runtime_pollWait(0x7ff1462e4870, 0x72)
2023-11-17 21:28:18.557373698 runtime/netpoll.go:343 +0x85
2023-11-17 21:28:18.557374541 internal/poll.(*pollDesc).wait(0xc078affe00?, 0xc07ae1e000?, 0x0)
2023-11-17 21:28:18.557375318 internal/poll/fd_poll_runtime.go:84 +0x27
2023-11-17 21:28:18.557376078 internal/poll.(*pollDesc).waitRead(...)
2023-11-17 21:28:18.557376802 internal/poll/fd_poll_runtime.go:89
2023-11-17 21:28:18.557377692 internal/poll.(*FD).Read(0xc078affe00, {0xc07ae1e000, 0x10000, 0x10000})
2023-11-17 21:28:18.557378438 internal/poll/fd_unix.go:164 +0x27a
2023-11-17 21:28:18.557397859 net.(*netFD).Read(0xc078affe00, {0xc07ae1e000?, 0x4d4b45?, 0xc078da36e8?})
2023-11-17 21:28:18.557398741 net/fd_posix.go:55 +0x25
2023-11-17 21:28:18.557399636 net.(*conn).Read(0xc0732502d8, {0xc07ae1e000?, 0xc04ce1b600?, 0x2?})
2023-11-17 21:28:18.557400367 net/net.go:179 +0x45
2023-11-17 21:28:18.557401120 bufio.(*Reader).fill(0xc078b644e0)
2023-11-17 21:28:18.557401852 bufio/bufio.go:113 +0x103
2023-11-17 21:28:18.557402648 bufio.(*Reader).ReadSlice(0xc078b644e0, 0xb8?)
2023-11-17 21:28:18.557403367 bufio/bufio.go:379 +0x29
2023-11-17 21:28:18.557404122 bufio.(*Reader).ReadLine(0xc078b644e0)
2023-11-17 21:28:18.557404823 bufio/bufio.go:408 +0x25
2023-11-17 21:28:18.557405654 net/textproto.(*Reader).readLineSlice(0xc078da3970)
2023-11-17 21:28:18.557406375 net/textproto/reader.go:56 +0x99
2023-11-17 21:28:18.557407098 net/textproto.(*Reader).ReadLine(...)
2023-11-17 21:28:18.557407810 net/textproto/reader.go:39
2023-11-17 21:28:18.557426620 github.com/AlexxIT/go2rtc/pkg/tcp.ReadResponse(0xc078b644e0)
2023-11-17 21:28:18.557427650 github.com/AlexxIT/go2rtc/pkg/tcp/textproto.go:46 +0x54
2023-11-17 21:28:18.557428549 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).ReadResponse(0xc07ad84000)
2023-11-17 21:28:18.557429362 github.com/AlexxIT/go2rtc/pkg/rtsp/conn.go:366 +0x77
2023-11-17 21:28:18.557430278 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Do(0xc07ad84000, 0xc07aae0640)
2023-11-17 21:28:18.557431101 github.com/AlexxIT/go2rtc/pkg/rtsp/client.go:65 +0x34
2023-11-17 21:28:18.557432060 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Describe(0xc07ad84000)
2023-11-17 21:28:18.557432903 github.com/AlexxIT/go2rtc/pkg/rtsp/client.go:134 +0x2de
2023-11-17 21:28:18.557433874 github.com/AlexxIT/go2rtc/internal/rtsp.rtspHandler({0xc0000ccb40?, 0xc00009ffb0?})
2023-11-17 21:28:18.557434719 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:126 +0x2f8
2023-11-17 21:28:18.557435612 github.com/AlexxIT/go2rtc/internal/streams.GetProducer({0xc0000ccb40, 0x28})
2023-11-17 21:28:18.557436469 github.com/AlexxIT/go2rtc/internal/streams/handlers.go:49 +0xcb
2023-11-17 21:28:18.557437378 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000debd0)
2023-11-17 21:28:18.557438216 github.com/AlexxIT/go2rtc/internal/streams/producer.go:62 +0x95
2023-11-17 21:28:18.557460453 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3cc0, {0xd2b760, 0xc00104e480})
2023-11-17 21:28:18.557461523 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.557462446 github.com/AlexxIT/go2rtc/internal/mp4.handlerWSMSE(0xc07a6fe3c0, 0xc078d4fec0)
2023-11-17 21:28:18.557463253 github.com/AlexxIT/go2rtc/internal/mp4/ws.go:31 +0x545
2023-11-17 21:28:18.557464073 github.com/AlexxIT/go2rtc/internal/api/ws.apiWS.func2()
2023-11-17 21:28:18.557464896 github.com/AlexxIT/go2rtc/internal/api/ws/ws.go:130 +0x39
2023-11-17 21:28:18.557465825 created by github.com/AlexxIT/go2rtc/internal/api/ws.apiWS in goroutine 280712
2023-11-17 21:28:18.557466672 github.com/AlexxIT/go2rtc/internal/api/ws/ws.go:129 +0x365
2023-11-17 21:28:18.557467268
2023-11-17 21:28:18.557467958 goroutine 280624 [runnable]:
2023-11-17 21:28:18.557468748 internal/poll.runtime_pollWait(0x7ff146384c28, 0x72)
2023-11-17 21:28:18.557469451 runtime/netpoll.go:343 +0x85
2023-11-17 21:28:18.557470289 internal/poll.(*pollDesc).wait(0xc078afec80?, 0xc070ccb900?, 0x0)
2023-11-17 21:28:18.557471052 internal/poll/fd_poll_runtime.go:84 +0x27
2023-11-17 21:28:18.557471800 internal/poll.(*pollDesc).waitRead(...)
2023-11-17 21:28:18.557472550 internal/poll/fd_poll_runtime.go:89
2023-11-17 21:28:18.557491977 internal/poll.(*FD).Read(0xc078afec80, {0xc070ccb900, 0x2, 0x2})
2023-11-17 21:28:18.557492935 internal/poll/fd_unix.go:164 +0x27a
2023-11-17 21:28:18.557493867 net.(*netFD).Read(0xc078afec80, {0xc070ccb900?, 0x7ff1471001d8?, 0x7ff192c9c108?})
2023-11-17 21:28:18.557494620 net/fd_posix.go:55 +0x25
2023-11-17 21:28:18.557495526 net.(*conn).Read(0xc07c7d3c30, {0xc070ccb900?, 0xb01be0?, 0x7ff192c9c101?})
2023-11-17 21:28:18.557496216 net/net.go:179 +0x45
2023-11-17 21:28:18.557497219 github.com/pion/ice/v2.readStreamingPacket({0xd31d90, 0xc07c7d3c30}, {0xc079138000, 0x0?, 0x2000})
2023-11-17 21:28:18.557498039 github.com/pion/ice/v2@v2.3.11/tcp_mux.go:362 +0x9b
2023-11-17 21:28:18.557498964 github.com/pion/ice/v2.(*TCPMuxDefault).handleConn(0xc00020c400, {0xd31d90?, 0xc07c7d3c30})
2023-11-17 21:28:18.557499776 github.com/pion/ice/v2@v2.3.11/tcp_mux.go:168 +0x8d
2023-11-17 21:28:18.557519094 github.com/pion/ice/v2.(*TCPMuxDefault).start.func1()
2023-11-17 21:28:18.557520068 github.com/pion/ice/v2@v2.3.11/tcp_mux.go:93 +0x57
2023-11-17 21:28:18.557521029 created by github.com/pion/ice/v2.(*TCPMuxDefault).start in goroutine 20
2023-11-17 21:28:18.557521833 github.com/pion/ice/v2@v2.3.11/tcp_mux.go:91 +0xbb
2023-11-17 21:28:18.557522437
2023-11-17 21:28:18.557523152 goroutine 280727 [chan receive]:
2023-11-17 21:28:18.557524071 github.com/pion/srtp/v2.(*SessionSRTP).AcceptStream(0x48941d1c3ce8003e?)
2023-11-17 21:28:18.557524916 github.com/pion/srtp/v2@v2.0.18/session_srtp.go:98 +0x26
2023-11-17 21:28:18.557525974 github.com/pion/webrtc/v3.(*PeerConnection).undeclaredRTPMediaProcessor(0xc002606900)
2023-11-17 21:28:18.557526876 github.com/pion/webrtc/v3@v3.2.22/peerconnection.go:1650 +0xd1
2023-11-17 21:28:18.557547516 created by github.com/pion/webrtc/v3.(*PeerConnection).undeclaredMediaProcessor in goroutine 280663
2023-11-17 21:28:18.557548531 github.com/pion/webrtc/v3@v3.2.22/peerconnection.go:1637 +0x56
2023-11-17 21:28:18.557549167
2023-11-17 21:28:18.557549870 goroutine 280728 [chan receive]:
2023-11-17 21:28:18.557550763 github.com/pion/srtp/v2.(*SessionSRTCP).AcceptStream(0xb358a78cd7d00e7e?)
2023-11-17 21:28:18.557551607 github.com/pion/srtp/v2@v2.0.18/session_srtcp.go:96 +0x26
2023-11-17 21:28:18.557552539 github.com/pion/webrtc/v3.(*PeerConnection).undeclaredRTCPMediaProcessor(0xc002606900)
2023-11-17 21:28:18.557553396 github.com/pion/webrtc/v3@v3.2.22/peerconnection.go:1694 +0x119
2023-11-17 21:28:18.557554423 created by github.com/pion/webrtc/v3.(*PeerConnection).undeclaredMediaProcessor in goroutine 280663
2023-11-17 21:28:18.557555276 github.com/pion/webrtc/v3@v3.2.22/peerconnection.go:1638 +0x96
2023-11-17 21:28:18.557555872
2023-11-17 21:28:18.557556547 goroutine 280715 [select]:
2023-11-17 21:28:18.557577139 github.com/AlexxIT/go2rtc/internal/exec.handleRTSP({0xc078eafa00, 0x1e1}, {0xc075f77170, 0x21}, 0xc07ad842c0)
2023-11-17 21:28:18.557578164 github.com/AlexxIT/go2rtc/internal/exec/exec.go:127 +0x44e
2023-11-17 21:28:18.557579113 github.com/AlexxIT/go2rtc/internal/exec.execHandle({0xc078eafa00, 0x1e1})
2023-11-17 21:28:18.557579987 github.com/AlexxIT/go2rtc/internal/exec/exec.go:73 +0x234
2023-11-17 21:28:18.557580932 github.com/AlexxIT/go2rtc/internal/streams.GetProducer({0xc078eafa00, 0x1e1})
2023-11-17 21:28:18.557581777 github.com/AlexxIT/go2rtc/internal/streams/handlers.go:49 +0xcb
2023-11-17 21:28:18.557582700 github.com/AlexxIT/go2rtc/internal/streams.GetProducer({0xc0000ccb10, 0x29})
2023-11-17 21:28:18.557583569 github.com/AlexxIT/go2rtc/internal/streams/handlers.go:44 +0xd6
2023-11-17 21:28:18.557584504 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000deb40)
2023-11-17 21:28:18.557585373 github.com/AlexxIT/go2rtc/internal/streams/producer.go:62 +0x95
2023-11-17 21:28:18.557586396 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3cc0, {0xd2b940, 0xc00019e3c0})
2023-11-17 21:28:18.557605948 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.557607061 github.com/AlexxIT/go2rtc/internal/webrtc.asyncHandler(0xc07a6fe3c0, 0xc078d4fee0)
2023-11-17 21:28:18.557607930 github.com/AlexxIT/go2rtc/internal/webrtc/webrtc.go:171 +0x6a5
2023-11-17 21:28:18.557608777 github.com/AlexxIT/go2rtc/internal/api/ws.apiWS.func2()
2023-11-17 21:28:18.557609634 github.com/AlexxIT/go2rtc/internal/api/ws/ws.go:130 +0x39
2023-11-17 21:28:18.557610532 created by github.com/AlexxIT/go2rtc/internal/api/ws.apiWS in goroutine 280712
2023-11-17 21:28:18.557630936 github.com/AlexxIT/go2rtc/internal/api/ws/ws.go:129 +0x365
2023-11-17 21:28:18.557631722
2023-11-17 21:28:18.557632475 goroutine 280772 [sync.Mutex.Lock]:
2023-11-17 21:28:18.557633339 sync.runtime_SemacquireMutex(0xc24fb8?, 0x19?, 0x3e4df2a62c068770?)
2023-11-17 21:28:18.557634037 runtime/sema.go:77 +0x25
2023-11-17 21:28:18.557634760 sync.(*Mutex).lockSlow(0xc0000de85c)
2023-11-17 21:28:18.557635485 sync/mutex.go:171 +0x15d
2023-11-17 21:28:18.557636178 sync.(*Mutex).Lock(...)
2023-11-17 21:28:18.557636834 sync/mutex.go:90
2023-11-17 21:28:18.557637712 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000de7e0)
2023-11-17 21:28:18.557638543 github.com/AlexxIT/go2rtc/internal/streams/producer.go:58 +0x52
2023-11-17 21:28:18.557639537 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3b40, {0xd2b910, 0xc07a0b3e40})
2023-11-17 21:28:18.557640415 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.557659774 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.557660774 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.557661609 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.557662430 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.557663306 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc07a0b3e40)
2023-11-17 21:28:18.557664133 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.557665011 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc07a0b3e40)
2023-11-17 21:28:18.557665839 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.557666748 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.557667605 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:18.557668193
2023-11-17 21:28:18.557668863 goroutine 280687 [select]:
2023-11-17 21:28:18.557669902 github.com/pion/interceptor/pkg/report.(*SenderInterceptor).loop(0xc078bfca80, {0xd28840, 0xc078e030a0})
2023-11-17 21:28:18.557690766 github.com/pion/interceptor@v0.1.25/pkg/report/sender_interceptor.go:116 +0x1ee
2023-11-17 21:28:18.557691959 created by github.com/pion/interceptor/pkg/report.(*SenderInterceptor).BindRTCPWriter in goroutine 280715
2023-11-17 21:28:18.557692925 github.com/pion/interceptor@v0.1.25/pkg/report/sender_interceptor.go:100 +0x12b
2023-11-17 21:28:18.557693501
2023-11-17 21:28:18.557694154 goroutine 280688 [select]:
2023-11-17 21:28:18.557695134 github.com/pion/interceptor/pkg/twcc.(*SenderInterceptor).loop(0xc078e2e3c0, {0xd28840, 0xc078e030a0})
2023-11-17 21:28:18.557696053 github.com/pion/interceptor@v0.1.25/pkg/twcc/sender_interceptor.go:180 +0xe6
2023-11-17 21:28:18.557697076 created by github.com/pion/interceptor/pkg/twcc.(*SenderInterceptor).BindRTCPWriter in goroutine 280715
2023-11-17 21:28:18.557698003 github.com/pion/interceptor@v0.1.25/pkg/twcc/sender_interceptor.go:93 +0x16b
2023-11-17 21:28:18.557698600
2023-11-17 21:28:18.557699318 goroutine 280653 [sync.Mutex.Lock]:
2023-11-17 21:28:18.557700212 sync.runtime_SemacquireMutex(0xc24fb8?, 0x19?, 0x3e4df2a600126620?)
2023-11-17 21:28:18.557700928 runtime/sema.go:77 +0x25
2023-11-17 21:28:18.557701668 sync.(*Mutex).lockSlow(0xc0000de85c)
2023-11-17 21:28:18.557702347 sync/mutex.go:171 +0x15d
2023-11-17 21:28:18.557703027 sync.(*Mutex).Lock(...)
2023-11-17 21:28:18.557723676 sync/mutex.go:90
2023-11-17 21:28:18.557724741 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000de7e0)
2023-11-17 21:28:18.557725624 github.com/AlexxIT/go2rtc/internal/streams/producer.go:58 +0x52
2023-11-17 21:28:18.557726628 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3b40, {0xd2b910, 0xc078b63760})
2023-11-17 21:28:18.557727519 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.557728449 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.557729277 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.557730097 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.557730884 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.557731723 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc078b63760)
2023-11-17 21:28:18.557732568 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.557733423 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc078b63760)
2023-11-17 21:28:18.557734277 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.557735184 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.557736034 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:18.557736628
2023-11-17 21:28:18.557757658 goroutine 280774 [runnable]:
2023-11-17 21:28:18.557759053 syscall.Syscall6(0x87c1112afeff6225?, 0xa737d3808d743b53?, 0x754f82f09dfec291?, 0xd4d960763f758f79?, 0x305bd184b56ce1e7?, 0xfbbb82f6a80ee410?, 0x60a7876b?)
2023-11-17 21:28:18.557759822 syscall/syscall_linux.go:91 +0x30
2023-11-17 21:28:18.557760629 os.(*Process).blockUntilWaitable(0xc075f771a0)
2023-11-17 21:28:18.557761353 os/wait_waitid.go:32 +0x76
2023-11-17 21:28:18.557762064 os.(*Process).wait(0xc075f771a0)
2023-11-17 21:28:18.557762774 os/exec_unix.go:22 +0x25
2023-11-17 21:28:18.557763454 os.(*Process).Wait(...)
2023-11-17 21:28:18.557764100 os/exec.go:134
2023-11-17 21:28:18.557764819 os/exec.(*Cmd).Wait(0xc07ad842c0)
2023-11-17 21:28:18.557765501 os/exec/exec.go:890 +0x45
2023-11-17 21:28:18.557766327 github.com/AlexxIT/go2rtc/internal/exec.handleRTSP.func2()
2023-11-17 21:28:18.557767168 github.com/AlexxIT/go2rtc/internal/exec/exec.go:118 +0x36
2023-11-17 21:28:18.557768118 created by github.com/AlexxIT/go2rtc/internal/exec.handleRTSP in goroutine 280715
2023-11-17 21:28:18.557768931 github.com/AlexxIT/go2rtc/internal/exec/exec.go:117 +0x3a6
2023-11-17 21:28:18.557769517
2023-11-17 21:28:18.557770194 goroutine 280771 [IO wait]:
2023-11-17 21:28:18.557790733 internal/poll.runtime_pollWait(0x7ff1462e4a60, 0x72)
2023-11-17 21:28:18.557791634 runtime/netpoll.go:343 +0x85
2023-11-17 21:28:18.557792545 internal/poll.(*pollDesc).wait(0xc078d53c00?, 0xc07acde000?, 0x0)
2023-11-17 21:28:18.557793295 internal/poll/fd_poll_runtime.go:84 +0x27
2023-11-17 21:28:18.557794076 internal/poll.(*pollDesc).waitRead(...)
2023-11-17 21:28:18.557794834 internal/poll/fd_poll_runtime.go:89
2023-11-17 21:28:18.557795731 internal/poll.(*FD).Read(0xc078d53c00, {0xc07acde000, 0x10000, 0x10000})
2023-11-17 21:28:18.557796480 internal/poll/fd_unix.go:164 +0x27a
2023-11-17 21:28:18.557797358 net.(*netFD).Read(0xc078d53c00, {0xc07acde000?, 0x0?, 0xc000000001?})
2023-11-17 21:28:18.557798072 net/fd_posix.go:55 +0x25
2023-11-17 21:28:18.557798908 net.(*conn).Read(0xc0732502d0, {0xc07acde000?, 0x0?, 0xc076a69580?})
2023-11-17 21:28:18.557799556 net/net.go:179 +0x45
2023-11-17 21:28:18.557800269 bufio.(*Reader).fill(0xc078b64480)
2023-11-17 21:28:18.557823980 bufio/bufio.go:113 +0x103
2023-11-17 21:28:18.557824967 bufio.(*Reader).ReadSlice(0xc078b64480, 0xa8?)
2023-11-17 21:28:18.557825710 bufio/bufio.go:379 +0x29
2023-11-17 21:28:18.557826460 bufio.(*Reader).ReadLine(0xc078b64480)
2023-11-17 21:28:18.557827163 bufio/bufio.go:408 +0x25
2023-11-17 21:28:18.557827973 net/textproto.(*Reader).readLineSlice(0xc076a69788)
2023-11-17 21:28:18.557828712 net/textproto/reader.go:56 +0x99
2023-11-17 21:28:18.557829455 net/textproto.(*Reader).ReadLine(...)
2023-11-17 21:28:18.557830153 net/textproto/reader.go:39
2023-11-17 21:28:18.557830986 github.com/AlexxIT/go2rtc/pkg/tcp.ReadResponse(0xc078b64480)
2023-11-17 21:28:18.557831811 github.com/AlexxIT/go2rtc/pkg/tcp/textproto.go:46 +0x54
2023-11-17 21:28:18.557832694 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).ReadResponse(0xc079b58f20)
2023-11-17 21:28:18.557833504 github.com/AlexxIT/go2rtc/pkg/rtsp/conn.go:366 +0x77
2023-11-17 21:28:18.557834410 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Do(0xc079b58f20, 0xc07aae0460)
2023-11-17 21:28:18.557835230 github.com/AlexxIT/go2rtc/pkg/rtsp/client.go:65 +0x34
2023-11-17 21:28:18.557836105 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Describe(0xc079b58f20)
2023-11-17 21:28:18.557836897 github.com/AlexxIT/go2rtc/pkg/rtsp/client.go:134 +0x2de
2023-11-17 21:28:18.557856988 github.com/AlexxIT/go2rtc/internal/rtsp.rtspHandler({0xc0000ccae0?, 0xc00009ffb0?})
2023-11-17 21:28:18.557858018 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:126 +0x2f8
2023-11-17 21:28:18.557858944 github.com/AlexxIT/go2rtc/internal/streams.GetProducer({0xc0000ccae0, 0x28})
2023-11-17 21:28:18.557859822 github.com/AlexxIT/go2rtc/internal/streams/handlers.go:49 +0xcb
2023-11-17 21:28:18.557860725 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000df0e0)
2023-11-17 21:28:18.557861616 github.com/AlexxIT/go2rtc/internal/streams/producer.go:62 +0x95
2023-11-17 21:28:18.557862644 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3e00, {0xd2b910, 0xc07a0b3ce0})
2023-11-17 21:28:18.557863548 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.557864488 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.557865376 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.557866205 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.557867090 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.557867959 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc07a0b3ce0)
2023-11-17 21:28:18.557887199 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.557888229 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc07a0b3ce0)
2023-11-17 21:28:18.557889145 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.557890071 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.557890900 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:18.557891491
2023-11-17 21:28:18.557892204 goroutine 280769 [sync.Mutex.Lock]:
2023-11-17 21:28:18.557893056 sync.runtime_SemacquireMutex(0xc24fb8?, 0x19?, 0x3e4df2a600c000e0?)
2023-11-17 21:28:18.557893769 runtime/sema.go:77 +0x25
2023-11-17 21:28:18.557894527 sync.(*Mutex).lockSlow(0xc0000de85c)
2023-11-17 21:28:18.557895210 sync/mutex.go:171 +0x15d
2023-11-17 21:28:18.557895895 sync.(*Mutex).Lock(...)
2023-11-17 21:28:18.557896553 sync/mutex.go:90
2023-11-17 21:28:18.557897457 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000de7e0)
2023-11-17 21:28:18.557898322 github.com/AlexxIT/go2rtc/internal/streams/producer.go:58 +0x52
2023-11-17 21:28:18.557899348 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3b40, {0xd2b910, 0xc07a0b2840})
2023-11-17 21:28:18.557921174 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.557922278 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.557923158 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.557923978 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.557924783 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.557925618 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc07a0b2840)
2023-11-17 21:28:18.557926465 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.557927291 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc07a0b2840)
2023-11-17 21:28:18.557928139 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.557929032 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.557929863 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:18.557930460
2023-11-17 21:28:18.557931160 goroutine 280740 [chan receive]:
2023-11-17 21:28:18.557932012 github.com/AlexxIT/go2rtc/pkg/core.(*Sender).HandleRTP.func1()
2023-11-17 21:28:18.557932834 github.com/AlexxIT/go2rtc/pkg/core/track.go:142 +0x71
2023-11-17 21:28:18.557933743 created by github.com/AlexxIT/go2rtc/pkg/core.(*Sender).HandleRTP in goroutine 280756
2023-11-17 21:28:18.557934559 github.com/AlexxIT/go2rtc/pkg/core/track.go:140 +0x359
2023-11-17 21:28:18.557935156
2023-11-17 21:28:18.557954423 goroutine 280739 [sync.Mutex.Lock]:
2023-11-17 21:28:18.557955462 sync.runtime_SemacquireMutex(0x7ff192c9ca68?, 0x10?, 0xc000091800?)
2023-11-17 21:28:18.557956220 runtime/sema.go:77 +0x25
2023-11-17 21:28:18.557956981 sync.(*Mutex).lockSlow(0xc0000de85c)
2023-11-17 21:28:18.557957673 sync/mutex.go:171 +0x15d
2023-11-17 21:28:18.557958355 sync.(*Mutex).Lock(...)
2023-11-17 21:28:18.557959034 sync/mutex.go:90
2023-11-17 21:28:18.557959941 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000de7e0)
2023-11-17 21:28:18.557960803 github.com/AlexxIT/go2rtc/internal/streams/producer.go:58 +0x52
2023-11-17 21:28:18.557961845 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3b40, {0xd2b910, 0xc07a8e3600})
2023-11-17 21:28:18.557962711 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.557963616 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.557964444 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.557965263 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.557984501 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.557985521 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc07a8e3600)
2023-11-17 21:28:18.557986364 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.557987190 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc07a8e3600)
2023-11-17 21:28:18.557988038 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.557988971 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.557989837 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:18.557990440
2023-11-17 21:28:18.557991139 goroutine 280655 [sync.Mutex.Lock]:
2023-11-17 21:28:18.557991973 sync.runtime_SemacquireMutex(0xc24fb8?, 0x19?, 0x3e4df2a600126620?)
2023-11-17 21:28:18.557992685 runtime/sema.go:77 +0x25
2023-11-17 21:28:18.557993421 sync.(*Mutex).lockSlow(0xc0000de85c)
2023-11-17 21:28:18.557994111 sync/mutex.go:171 +0x15d
2023-11-17 21:28:18.557994820 sync.(*Mutex).Lock(...)
2023-11-17 21:28:18.557995481 sync/mutex.go:90
2023-11-17 21:28:18.557996376 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000de7e0)
2023-11-17 21:28:18.557997247 github.com/AlexxIT/go2rtc/internal/streams/producer.go:58 +0x52
2023-11-17 21:28:18.558020002 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3b40, {0xd2b910, 0xc07acdb1e0})
2023-11-17 21:28:18.558021080 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.558022023 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.558022865 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.558023694 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.558024487 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.558025309 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc07acdb1e0)
2023-11-17 21:28:18.558026120 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.558026939 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc07acdb1e0)
2023-11-17 21:28:18.558027775 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.558028710 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.558029546 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:18.558030140
2023-11-17 21:28:18.558030836 goroutine 280744 [sync.Mutex.Lock]:
2023-11-17 21:28:18.558031674 sync.runtime_SemacquireMutex(0x7ff192c9ca68?, 0x10?, 0xc000282c00?)
2023-11-17 21:28:18.558032385 runtime/sema.go:77 +0x25
2023-11-17 21:28:18.558052832 sync.(*Mutex).lockSlow(0xc0000de85c)
2023-11-17 21:28:18.558053736 sync/mutex.go:171 +0x15d
2023-11-17 21:28:18.558054461 sync.(*Mutex).Lock(...)
2023-11-17 21:28:18.558055117 sync/mutex.go:90
2023-11-17 21:28:18.558056036 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000de7e0)
2023-11-17 21:28:18.558056906 github.com/AlexxIT/go2rtc/internal/streams/producer.go:58 +0x52
2023-11-17 21:28:18.558057950 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3b40, {0xd2b910, 0xc0794c7b80})
2023-11-17 21:28:18.558058851 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.558059755 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.558060567 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.558061383 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.558062181 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.558063033 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc0794c7b80)
2023-11-17 21:28:18.558063867 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.558064726 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc0794c7b80)
2023-11-17 21:28:18.558065547 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.558084510 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.558085557 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:18.558086177
2023-11-17 21:28:18.558086875 goroutine 280745 [sync.Mutex.Lock]:
2023-11-17 21:28:18.558087737 sync.runtime_SemacquireMutex(0xc24fb8?, 0x19?, 0x3e4df2a62c068770?)
2023-11-17 21:28:18.558088414 runtime/sema.go:77 +0x25
2023-11-17 21:28:18.558089172 sync.(*Mutex).lockSlow(0xc0000de85c)
2023-11-17 21:28:18.558089875 sync/mutex.go:171 +0x15d
2023-11-17 21:28:18.558090559 sync.(*Mutex).Lock(...)
2023-11-17 21:28:18.558091250 sync/mutex.go:90
2023-11-17 21:28:18.558092089 github.com/AlexxIT/go2rtc/internal/streams.(*Producer).Dial(0xc0000de7e0)
2023-11-17 21:28:18.558092939 github.com/AlexxIT/go2rtc/internal/streams/producer.go:58 +0x52
2023-11-17 21:28:18.558093933 github.com/AlexxIT/go2rtc/internal/streams.(*Stream).AddConsumer(0xc0000c3b40, {0xd2b910, 0xc07bf00420})
2023-11-17 21:28:18.558094792 github.com/AlexxIT/go2rtc/internal/streams/add_consumer.go:26 +0x4c7
2023-11-17 21:28:18.558095716 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler.func1({0xb018a0?, 0xd24e80?})
2023-11-17 21:28:18.558211282 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:191 +0x605
2023-11-17 21:28:18.558213055 github.com/AlexxIT/go2rtc/pkg/core.(*Listener).Fire(...)
2023-11-17 21:28:18.558213898 github.com/AlexxIT/go2rtc/pkg/core/listener.go:16
2023-11-17 21:28:18.558214781 github.com/AlexxIT/go2rtc/pkg/rtsp.(*Conn).Accept(0xc07bf00420)
2023-11-17 21:28:18.558215628 github.com/AlexxIT/go2rtc/pkg/rtsp/server.go:97 +0xc02
2023-11-17 21:28:18.558216500 github.com/AlexxIT/go2rtc/internal/rtsp.tcpHandler(0xc07bf00420)
2023-11-17 21:28:18.558217399 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:223 +0x198
2023-11-17 21:28:18.558218354 created by github.com/AlexxIT/go2rtc/internal/rtsp.Init.func1 in goroutine 19
2023-11-17 21:28:18.558219201 github.com/AlexxIT/go2rtc/internal/rtsp/rtsp.go:75 +0x45
2023-11-17 21:28:19.012546334 curl: (56) Recv failure: Connection reset by peer
2023-11-17 21:28:19.012550118 [ERROR] The go2rtc service is not responding to ping, restarting...
2023-11-17 21:28:19.081913903 [INFO] The go2rtc service exited with code 2 (by signal 0)
2023-11-17 21:28:20.098833512 [WARN] Using go2rtc binary from '/config/go2rtc' instead of the embedded one
2023-11-17 21:28:20.098857957 [INFO] Starting go2rtc...
2023-11-17 21:28:20.166347356 18:28:20.166 INF go2rtc version 1.8.3 linux/amd64
2023-11-17 21:28:20.166776550 18:28:20.166 INF [api] listen addr=:1984
2023-11-17 21:28:20.166971173 18:28:20.166 INF [rtsp] listen addr=:8554
2023-11-17 21:28:20.167185911 18:28:20.167 INF [webrtc] listen addr=:8555
2023-11-18 01:32:27.589309514 22:32:27.589 WRN github.com/AlexxIT/go2rtc/internal/streams/producer.go:171 > error="read tcp 172.30.33.6:37414->192.168.1.21:554: i/o timeout" url=rtsp://192.168.1.21/user=tema_password=pass_channel=0_stream=1&onvif=0.sdp?real_stream
But this one even made go2rtc crash and get stuck, which caused the go2rtc watchdog from Frigate to restart it. I am not sure if it is directly related with the problem that I am reporting itself.
Another note is that, previously, preloading the stream in Home Assistant was apparently enough to solve this problem, but it no longer is. go2rtc loses the connection and does not recover even if Frigate is consuming the stream 100% of the time.
About this issue
- Original URL
- State: open
- Created 7 months ago
- Reactions: 1
- Comments: 20 (12 by maintainers)
oh the port 1984 is only for gortc? i am using frigate docker
(?) My automation restarts go2rtc only.
No, I’m just using the latest beta integration.
unfortunately i cant have stream preloading since i need the
ffmpeg:
directive in the source