Galène videoconferencing server discussion list archives
 help / color / mirror / Atom feed
From: Juliusz Chroboczek <jch@irif.fr>
To: galene@lists.galene.org
Subject: [Galene] About UDP multiplexing
Date: Sat, 22 Mar 2025 19:29:10 +0100	[thread overview]
Message-ID: <87v7s0or61.wl-jch@irif.fr> (raw)

Hi,

By default, Galene will use random UDP ports for media traffic.  If the
high ports are inaccessible for some reason (say, because there is
a firewall in the way), it will fall back to routing through the built-in
TURN server.  While this is the right approach, it makes Galene
challenging to install for people who wish to put it behind a firewall.

There is another approach, which is to put all the UDP traffic on a single
port; this is called UDP multiplexing.  I tried it a couple of years ago,
and it did not work well, apparently Pion (our WebRTC library) had some
issues with double-stack hosts when multiplexing.  It appears to work now,
and I've implemented it in the branch "udpmux".

UDP muxing is very simple to use: just add the option "-udp 10000", where
10000 is the port that you wish to use for UDP traffic.  There are some
caveats:

  - there is a slight performance penalty, but it should be negligible;

  - if the server is renumbered (its IP address changes), you will need
    to restart Galene.

The code is live on galene.org, and it seems to work fine.  I've
reimplemented it just today, so if you did test before, please test again.

Note that UDP muxing, in its current state, does not solve the NAT
problem: if your server is behind NAT, Galene will still fallback to TURN,
even if the mux port is forwarded on the NAT.  I'll see if I can implement
something, but please don't hold your breath, I'm not really interested in
working around NAT issues.

-- Juliusz

  

             reply	other threads:[~2025-03-22 18:29 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-03-22 18:29 Juliusz Chroboczek [this message]
2025-03-22 20:32 ` [Galene] " Dirk-Willem van Gulik
2025-03-23  9:59   ` Juliusz Chroboczek
2025-03-23 11:42     ` Dirk-Willem van Gulik
2025-03-30 21:22       ` Juliusz Chroboczek
2025-03-31  4:29         ` Gabriel Pruvost-Kerneis
2025-03-31 11:46           ` Juliusz Chroboczek

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://lists.galene.org/postorius/lists/galene.lists.galene.org/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87v7s0or61.wl-jch@irif.fr \
    --to=jch@irif.fr \
    --cc=galene@lists.galene.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox