Skip to content

Running a Private Server

Diego de la Hera edited this page Aug 11, 2020 · 26 revisions

Home > Running a Server > Running a Private Server

Please ensure you have read the server overview

This guide assumes you will be running a private server on your home network, but some of the issues here may also apply to those running on cloud hosts (eg Amazon EC2).

It is also highly recommended to test your server in public mode first so as to narrow down any subsequent problems in private mode.

Operating a private server behind a home network router

Port forwarding

(If you are curious about why you need to do this for private but not public servers, see this footnote.)

Normally, people from outside your home network cannot see things inside it. So if you want to operate a Jamulus server at home, you need to open a hole in your router to let Jamulus clients connect to it.

The default port for the current version of the Jamulus software is UDP (not TCP) port 22124.

Here's an example of the port forwarding settings in a Linksys router:

Linksys screenshot

See also portforward.com.

Once you have your router set up, you can get your external (WAN) IP address using Google. Give this address to your friends so they can connect to your server (but see also the note on dynamic DNS below).

Points to note

  • You do not need to open a port range as shown in the example above as long as you want to start only one instance of the Jamulus server on the same machine.

  • If using a different port than the default port (22124) you have to enter the port number after the server name or IP address separated by a colon in the Jamulus client (e. g. jamulus.dyndns.org:22120).

  • See also this excellent guide to running a private server by Simon Tomlinson on Facebook.

Dynamic DNS and why you will probably need it

Most domestic Internet connections will change their IP address after a period (hours, days or weeks). To make it easier for people to connect to you, you may therefore also want set up a dynamic DNS address. You can do this on the machine that you are running the Jamulus server on, or preferably your router may support it.

Note also that your home router may also change the IP address of the machine that you are running your server on. In which case you may need either to give that machine a static IP in the router's DHCP configuration, or simply port forward to all the addresses in your LAN.

Footnote for geeks

One of the many features of Jamulus that make it orgasmically wonderful is the fact that you can set up a server in seconds. But why do public servers not need port forwarding to do this?

Normally, network address translation (NAT) firewalls prevent incoming requests initiated from outside the local network. Inbound traffic is only possible for packets relating to an outbound request (strictly speaking, "related" and "established" packets to an initial outbound connection). In public mode, when a Jamulus server connects to a Central Server it of course initiates an outbound connection. From then on, the Central Server sends (established/related) connection "pings" (not ICMP pings) to that server at regular intervals to keep the relevant NAT port(s) open on the router/firewall.

When a client contacts a Central Server, the Central Server sends this client's information (IP and port) to all servers registered at the Central Server. Then, each server sends a ping to the client (see here). This technique allows traffic from clients to pass through from the Internet in a direction that would otherwise be blocked by the way network address translation works.

However, in private mode clients have to initiate connections into the server's network. NAT firewalls prevent this, so you need to tell them to allow incoming connection requests on the Jamulus port using port forwarding.