Open spscream opened 4 weeks ago
Hello.
We encountered a similar problem with Janus in a docker container started on a host where IPv6 is disabled and with an RTSP stream. The container is based on a debian:12-slim image.
We patched by adding the line
family = AF_INET;
just before https://github.com/meetecho/janus-gateway/blob/master/src/plugins/janus_streaming.c#L7289.
It's dirty, but it allowed us to run the stream for test purposes while waiting for a fix or before switching to an alternative solution such as MediaMTX.
The Streaming plugin probably just needs the ipv6_disabled
property we added to other plugins (e.g. AudioBridge and VideoRoom), where we basically try and create an IPv6 socket as soon as the plugin is loaded, and if that fails, we set ipv6_disabled = FALSE
which then impacts how sockets are created, for instance:
audiobridge->rtp_udp_sock = socket(!ipv6_disabled ? AF_INET6 : AF_INET, SOCK_DGRAM, IPPROTO_UDP);
There may be a reason why we didn't add it to the Streaming plugin too, back then, but on the top of my head I can't remember if that was the case.
There may be a reason why we didn't add it to the Streaming plugin too, back then, but on the top of my head I can't remember if that was the case.
Checking the code, even in the VideoRoom where we have the IPv6 check, we actually only use it for forwarders but not for the RTCP socket, which is a socket that expects stuff on the way in, just as the Streaming plugin does in general for media too. I'll have to check my old notes to see if there was a reason why we didn't extend that to sockets for incoming data as well, rather than just sockets for sending data.
What version of Janus is this happening on? master
Have you tested a more recent version of Janus too? no
Was this working before? I don't have information
Is there a gdb or libasan trace of the issue? no
Additional context We have server with disabled ipv6 and if we create stream with following parameters:
we got an error:
if I specify
iface
parameter forcreate
all is working good. I think its due this ternary here(https://github.com/meetecho/janus-gateway/blob/master/src/plugins/janus_streaming.c#L7289):In case iface isn't set when family is 0, but AF_INET is 2.