Merge pull request #89 from canton7/feature/relay-docs

Add to the Relays page
This commit is contained in:
Audrius Butkevicius
2015-12-02 19:29:49 +00:00

View File

@@ -27,7 +27,30 @@ devices.
Running Your Own Relay
----------------------
To run a relay of your own, download the latest release of the `relay server <https://github.com/syncthing/relaysrv/releases>`__
Syncthing relies on a network of community-contributed relay servers. Anyone can
run a relay server, and it will automatically join the relay pool and be
available to Syncthing users. The current list of relays can be found at
https://relays.syncthing.net.
To run a relay of your own, you will first need a server. Running a relay from a
home computer is not recommended: the relay ideally needs to be running 24/7,
and home internet connections often have poor upload bandwidth.
The recommended specifications for a relay are:
========= ==============
CPU At least 1GHz
RAM At least 256MB
Bandwidth At least 1MBit/s in and out, the higher the better
Traffic At least 1TiB/month, the more the better
========= ==============
VPS's with these specs are available for about $5-$10/month.
Installing and Running
~~~~~~~~~~~~~~~~~~~~~~
Download the latest release of the `relay server <https://github.com/syncthing/relaysrv/releases>`__
for your operating system and architecture. Unpack the archive and save the
binary to a convenient place such as `/usr/local/bin`.
@@ -38,6 +61,10 @@ smooth operation::
Usage of relaysrv:
-debug
Enable debug output
-ext-address string
An optional address to advertising as being available on.
Allows listening on an unprivileged port with port forwarding from e.g.
443, and be connected to on port 443.
-global-rate int
Global rate limit, in bytes/s
-keys string
@@ -66,10 +93,10 @@ smooth operation::
Primarily, you need to decide on a directory to store the TLS key and
certificate and a listen port. The default listen port of 22067 works, but for
optimal compatibility a well known port for encrypted traffic such as 443 is
recommended. This may require `additional setup
<https://wiki.apache.org/httpd/NonRootPortBinding>`__ to work without running
as root or a privileged user. In principle something similar to this should
work on a Linux/Unix system::
recommended. This may require additional setup to work without running
as root or a privileged user, see `Running on port 443 as an unprivileged user`_
below. In principle something similar to this should work on a Linux/Unix
system::
$ sudo useradd relaysrv
$ sudo mkdir /etc/relaysrv
@@ -82,3 +109,35 @@ global relay pool, unless a ``-pools=""`` argument is given.
To make the relay server start automatically at boot, use the recommended
procedure for your operating system.
Running on port 443 as an unprivileged user
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
It is recommended that you run the relay on port 443 (or another port which is
commonly allowed through corporate firewalls), in order to maximise the chances
that people are able to connect. However, binding to ports below 1000 requires
root privileges, and running a relay as root is not recommended. Thankfully
there are a couple of approaches available to you.
One option is to run the relay on port 22067, and use an ``iptables`` rule
to forward traffic from port 443 to port 22067, for example::
iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 443 -j REDIRECT --to-port 22067
Or, if you're using ``ufw``, add the following to ``/etc/ufw/before.rules``::
*nat
:PREROUTING ACCEPT [0:0]
:POSTROUTING ACCEPT [0:0]
-A PREROUTING -i eth0 -p tcp --dport 443 -j REDIRECT --to-port 22067
COMMIT
You will need to start ``relaysrv`` with ``-ext-address ":443"``. This tells
``relaysrv`` that it can be contacted on port 443, even though it is listening
on port 22067. You will also need to let both port 443 and 22067 through your
firewall.
Another option is `described here <https://wiki.apache.org/httpd/NonRootPortBinding>`__,
although your milage may vary.