.\" Man page generated from reStructuredText. . . .nr rst2man-indent-level 0 . .de1 rstReportMargin \\$1 \\n[an-margin] level \\n[rst2man-indent-level] level margin: \\n[rst2man-indent\\n[rst2man-indent-level]] - \\n[rst2man-indent0] \\n[rst2man-indent1] \\n[rst2man-indent2] .. .de1 INDENT .\" .rstReportMargin pre: . RS \\$1 . nr rst2man-indent\\n[rst2man-indent-level] \\n[an-margin] . nr rst2man-indent-level +1 .\" .rstReportMargin post: .. .de UNINDENT . RE .\" indent \\n[an-margin] .\" old: \\n[rst2man-indent\\n[rst2man-indent-level]] .nr rst2man-indent-level -1 .\" new: \\n[rst2man-indent\\n[rst2man-indent-level]] .in \\n[rst2man-indent\\n[rst2man-indent-level]]u .. .TH "STDISCOSRV" "1" "Jun 02, 2024" "v1.27.7" "Syncthing" .SH NAME stdiscosrv \- Syncthing Discovery Server .SH SYNOPSIS .INDENT 0.0 .INDENT 3.5 .sp .EX stdiscosrv [\-cert=] [\-db\-dir=] [\-debug] [\-http] [\-key=] [\-listen=
] [\-metrics\-listen=
] [\-replicate=] [\-replication\-listen=
] .EE .UNINDENT .UNINDENT .SH DESCRIPTION .sp Syncthing relies on a discovery server to find peers on the internet. Anyone can run a discovery server and point Syncthing installations to it. The Syncthing project also maintains a global cluster for public use. .SH OPTIONS .INDENT 0.0 .TP .B \-cert= Certificate file (default “./cert.pem”). .UNINDENT .INDENT 0.0 .TP .B \-db\-dir= Database directory, where data is stored (default “./discovery.db”). .UNINDENT .INDENT 0.0 .TP .B \-debug Enable debug output. .UNINDENT .INDENT 0.0 .TP .B \-http Listen on HTTP (behind an HTTPS proxy). .UNINDENT .INDENT 0.0 .TP .B \-key= Key file (default “./key.pem”). .UNINDENT .INDENT 0.0 .TP .B \-listen=
Listen address (default “:8443”). .UNINDENT .INDENT 0.0 .TP .B \-metrics\-listen=
Prometheus compatible metrics endpoint listen address (default disabled). .UNINDENT .INDENT 0.0 .TP .B \-replicate= Replication peers, \X'tty: link mailto:id@address'\fI\%id@address\fP <\fBid@address\fP>\X'tty: link', comma separated .UNINDENT .INDENT 0.0 .TP .B \-replication\-listen=
Listen address for incoming replication connections (default “:19200”). .UNINDENT .SH POINTING SYNCTHING AT YOUR DISCOVERY SERVER .sp By default, Syncthing uses a number of global discovery servers, signified by the entry \fBdefault\fP in the list of discovery servers. To make Syncthing use your own instance of stdiscosrv, open up Syncthing’s web GUI. Go to settings, Global Discovery Server and add stdiscosrv’s host address to the comma\-separated list, e.g. \fBhttps://disco.example.com:8443/\fP\&. Note that stdiscosrv uses port 8443 by default. For stdiscosrv to be available over the internet with a dynamic IP address, you will need a dynamic DNS service. .sp Deprecated since version v0.14.44: Prior versions need \fB/v2/\fP appended to the discovery server address, e.g. \fBhttps://disco.example.com:8443/v2/\fP\&. .sp If you wish to use \fIonly\fP your own discovery server, remove the \fBdefault\fP entry from the list. .SH SETTING UP .SS Description .sp This guide assumes that you have already set up Syncthing. If you haven’t yet, head over to \X'tty: link #getting-started'\fI\%Getting Started\fP\X'tty: link' first. .SS Installing .sp Go to \X'tty: link https://github.com/syncthing/discosrv/releases'\fI\%releases\fP <\fBhttps://github.com/syncthing/discosrv/releases\fP>\X'tty: link' and download the file appropriate for your operating system. Unpacking it will yield a binary called \fBstdiscosrv\fP (or \fBstdiscosrv.exe\fP on Windows). Start this in whatever way you are most comfortable with; double clicking should work in any graphical environment. At first start, stdiscosrv will generate certificate files and database in the current directory unless given flags to the contrary. .sp The discovery server can also be obtained through apt, the Debian/Ubuntu package manager. Recent releases can be found at syncthing’s \X'tty: link https://apt.syncthing.net/'\fI\%apt repository\fP <\fBhttps://apt.syncthing.net/\fP>\X'tty: link'\&. The name of the package is syncthing\-discosrv. .SS Configuring .sp \fBNOTE:\fP .INDENT 0.0 .INDENT 3.5 If you are running an instance of Syncthing on the discovery server, you must either add that instance to other devices using a static address or bind the discovery server and Syncthing instances to different IP addresses. .UNINDENT .UNINDENT .SS Certificates .sp The discovery server provides service over HTTPS. To ensure secure connections from clients there are three options: .INDENT 0.0 .IP \(bu 2 Use a CA\-signed certificate pair for the domain name you will use for the discovery server. This is like any other HTTPS website; clients will authenticate the server based on its certificate and domain name. .IP \(bu 2 Use any certificate pair and let clients authenticate the server based on its “device ID” (similar to Syncthing\-to\-Syncthing authentication). This option can be used with the certificate automatically generated by the discovery server. .IP \(bu 2 Pass the \fB\-http\fP flag if the discovery server is behind an SSL\-secured reverse proxy. See below for configuration. .UNINDENT .sp For the first two options, the discovery server must be given the paths to the certificate and key at startup. This isn’t necessary with the \fBhttp\fP flag: .INDENT 0.0 .INDENT 3.5 .sp .EX $ stdiscosrv \-cert=/path/to/cert.pem \-key=/path/to/key.pem Server device ID is 7DDRT7J\-UICR4PM\-PBIZYL3\-MZOJ7X7\-EX56JP6\-IK6HHMW\-S7EK32W\-G3EUPQA .EE .UNINDENT .UNINDENT .sp The discovery server prints its device ID at startup. In case you are using a non CA signed certificate, this device ID (fingerprint) must be given to the clients in the discovery server URL: .INDENT 0.0 .INDENT 3.5 .sp .EX https://disco.example.com:8443/?id=7DDRT7J\-UICR4PM\-PBIZYL3\-MZOJ7X7\-EX56JP6\-IK6HHMW\-S7EK32W\-G3EUPQA .EE .UNINDENT .UNINDENT .sp Otherwise, the URL will be: .INDENT 0.0 .INDENT 3.5 .sp .EX https://disco.example.com:8443/ .EE .UNINDENT .UNINDENT .SS Replication .sp The discovery server can be deployed in a redundant, load sharing fashion. In this mode announcements are replicated from the server that receives them to other peer servers and queries can be answered equally by all servers. .sp Replication connections are encrypted and authenticated using TLS. The certificate is selected by the \fB\-cert\fP and \fB\-key\fP options and is thus shared with the main discovery API. If the \fB\-http\fP mode is used the certificate is not used for client requests but only for replication connections. .sp Authentication of replication connections is done using \X'tty: link https://docs.syncthing.net/dev/device-ids.html#id1'\fI\%Syncthing\-style device IDs\fP <\fBhttps://docs.syncthing.net/dev/device-ids.html#id1\fP>\X'tty: link' only \- CA verification is not available. The device IDs in question are those printed by the discovery server on startup. .sp Replication connections are unidirectional \- announcements are replication from the \fBsender\fP to a \fBlistener\fP\&. In order to have a bidirectional replication relationship between two servers both need to be configured as sender and listener. .sp As an example, lets assume two discovery servers: .INDENT 0.0 .IP \(bu 2 Server one is on 192.0.2.20 and has certificate ID I6K…H76 .IP \(bu 2 Server two is on 192.0.2.55 and has certificate ID MRI…7OK .UNINDENT .sp In order for both to replicate to the other and thus form a redundant pair, use the following commands. .sp On server one: .INDENT 0.0 .INDENT 3.5 .sp .EX $ stdiscosrv \-replicate=MRI...7OK@192.0.2.55:19200 .EE .UNINDENT .UNINDENT .sp On server two: .INDENT 0.0 .INDENT 3.5 .sp .EX $ stdiscosrv \-replicate=I6K...H76@192.0.2.20:19200 .EE .UNINDENT .UNINDENT .sp The \fB\-replicate\fP directive sets which remote device IDs are expected and allowed for both outgoing (sending) and incoming (listening) connections, and which addresses to use when connecting out to those peers. Both IP and port must be specified in peer addresses. .sp It is possible to only allow incoming connections from a peer without establishing an outgoing replication connection. To do so, give only the device ID without “@ip:port” address: .INDENT 0.0 .INDENT 3.5 .sp .EX $ stdiscosrv \-replicate=I6K...H76 .EE .UNINDENT .UNINDENT .sp Discosrv will listen on the replication port only when \fB\-replicate\fP is given. The default replication listen address is “:19200”. .sp To achieve load balancing over two mutually replicating discovery server instances, add multiple A / AAAA DNS records for a given name and point Syncthing towards this name. The same certificate must be used on both discovery servers. .SS Reverse Proxy Setup .sp Added in version 1.8.0: A new “X\-Client\-Port” HTTP header was added. .sp The discovery server can be run behind an SSL\-secured reverse proxy. This allows: .INDENT 0.0 .IP \(bu 2 Use of a subdomain name without requiring a port number added to the URL .IP \(bu 2 Sharing an SSL certificate with multiple services on the same server .UNINDENT .sp Note that after this configuration, if the proxy uses a valid HTTPS certificate, \fBclients should omit the\fP \fB?id=...\fP \fBparameter from the discovery server URL on their configuration\fP\&. Client\-side validation will be done by checking the visible proxy server’s HTTPS certificate. If, however, the proxy uses a self\-signed or somehow invalid certificate, clients must still set the \fB?id=...\fP parameter with the computed hash of the proxy’s certificate. Using such setup is discouraged and is not covered in this page. Always favour using valid and widely recognised certificates. .SS Requirements .INDENT 0.0 .IP \(bu 2 Run the discovery server using the \-http flag: \fBstdiscosrv \-http\fP\&. .IP \(bu 2 SSL certificate/key configured for the reverse proxy. .IP \(bu 2 The “X\-Forwarded\-For” HTTP header must be passed through with the client’s real IP address. .IP \(bu 2 The “X\-Client\-Port” HTTP header should be passed through, containing the client’s real connection port. .IP \(bu 2 The “X\-SSL\-Cert” HTTP header must be passed through with the PEM\-encoded client SSL certificate. This will be present in POST requests and may be empty in GET requests from clients. If you see syncthing\-discosrv outputting \fBno certificates\fP when receiving POST requests, that’s because the proxy is not passing this header through. .IP \(bu 2 The proxy must request the client SSL certificate but not require it to be signed by a trusted CA. .UNINDENT .SS Nginx .sp These lines in the configuration take care of the last four requirements listed above: .INDENT 0.0 .INDENT 3.5 .sp .EX proxy_set_header X\-Forwarded\-For $proxy_add_x_forwarded_for; proxy_set_header X\-Client\-Port $remote_port; proxy_set_header X\-SSL\-Cert $ssl_client_cert; ssl_verify_client optional_no_ca; .EE .UNINDENT .UNINDENT .sp The following is a complete example Nginx configuration file. With this setup, clients can use \X'tty: link https://discovery.example.com'\fI\%https://discovery.example.com\fP\X'tty: link' as the discovery server URL in the Syncthing settings. .INDENT 0.0 .INDENT 3.5 .sp .EX # HTTP 1.1 support proxy_http_version 1.1; proxy_buffering off; proxy_set_header Host $http_host; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection $http_connection; proxy_set_header X\-Real\-IP $remote_addr; proxy_set_header X\-Client\-Port $remote_port; proxy_set_header X\-Forwarded\-For $proxy_add_x_forwarded_for; proxy_set_header X\-Forwarded\-Proto $http_x_forwarded_proto; proxy_set_header X\-SSL\-Cert $ssl_client_cert; upstream discovery.example.com { # Local IP address:port for discovery server server 192.0.2.1:8443; } server { server_name discovery.example.com; listen 80; access_log /var/log/nginx/access.log vhost; return 301 https://$host$request_uri; } server { server_name discovery.example.com; listen 443 ssl http2; access_log /var/log/nginx/access.log vhost; # Mozilla Intermediate configuration (https://wiki.mozilla.org/Security/Server_Side_TLS) ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers ECDHE\-ECDSA\-AES128\-GCM\-SHA256:ECDHE\-RSA\-AES128\-GCM\-SHA256:ECDHE\-ECDSA\-AES256\-GCM\-SHA384:ECDHE\-RSA\-AES256\-GCM\-SHA384:ECDHE\-ECDSA\-CHACHA20\-POLY1305:ECDHE\-RSA\-CHACHA20\-POLY1305:DHE\-RSA\-AES128\-GCM\-SHA256:DHE\-RSA\-AES256\-GCM\-SHA384; ssl_prefer_server_ciphers off; ssl_session_tickets off; ssl_session_timeout 5m; ssl_session_cache shared:SSL:50m; ssl_verify_client optional_no_ca; # OCSP stapling ssl_stapling on; ssl_stapling_verify on; # Certificates ssl_certificate /etc/nginx/certs/discovery.example.com.crt; ssl_certificate_key /etc/nginx/certs/discovery.example.com.key; # curl https://ssl\-config.mozilla.org/ffdhe2048.txt > /path/to/dhparam ssl_dhparam /path/to/dhparam; # HSTS (ngx_http_headers_module is required) (63072000 seconds) add_header Strict\-Transport\-Security \(dqmax\-age=63072000\(dq always; location / { proxy_pass http://discovery.example.com; } } .EE .UNINDENT .UNINDENT .sp An example of automating the SSL certificates and reverse\-proxying the Discovery Server and Syncthing using Nginx, \X'tty: link https://letsencrypt.org/'\fI\%Let’s Encrypt\fP <\fBhttps://letsencrypt.org/\fP>\X'tty: link' and Docker can be found \X'tty: link https://forum.syncthing.net/t/docker-syncthing-and-syncthing-discovery-behind-nginx-reverse-proxy-with-lets-encrypt/6880'\fI\%here\fP <\fBhttps://forum.syncthing.net/t/docker-syncthing-and-syncthing-discovery-behind-nginx-reverse-proxy-with-lets-encrypt/6880\fP>\X'tty: link'\&. .SS Apache .sp The following lines must be added to the configuration: .INDENT 0.0 .INDENT 3.5 .sp .EX SSLProxyEngine On SSLVerifyClient optional_no_ca RequestHeader set X\-SSL\-Cert \(dq%{SSL_CLIENT_CERT}s\(dq .EE .UNINDENT .UNINDENT .sp The following was observed to not be required at least under Apache httpd 2.4.38, as the proxy module adds the needed header by default. If you need to explicitly add the following directive, make sure to issue \fBa2enmod remoteip\fP first. Then, add the following to your Apache httpd configuration: .INDENT 0.0 .INDENT 3.5 .sp .EX RemoteIPHeader X\-Forwarded\-For .EE .UNINDENT .UNINDENT .SS Caddy .sp The following lines must be added to the Caddyfile: .INDENT 0.0 .INDENT 3.5 .sp .EX discovery.example.com { reverse_proxy 192.0.2.1:8443 { header_up X\-Forwarded\-For {http.request.remote.host} header_up X\-Client\-Port {http.request.remote.port} header_up X\-Tls\-Client\-Cert\-Der\-Base64 {http.request.tls.client.certificate_der_base64} } tls { client_auth { mode request } } } .EE .UNINDENT .UNINDENT .INDENT 0.0 .INDENT 3.5 .sp .EX .EE .UNINDENT .UNINDENT .sp For more details, see also the recommendations in the \X'tty: link https://docs.syncthing.net/users/reverseproxy.html'\fI\%Reverse Proxy Setup\fP <\fBhttps://docs.syncthing.net/users/reverseproxy.html\fP>\X'tty: link' page. Note that that page is directed at setting up a proxy for the Syncthing web UI. You should do the proper path and port adjustments to proxying the discovery server and your particular setup. .SH SEE ALSO .sp \fBsyncthing\-networking(7)\fP, \fBsyncthing\-faq(7)\fP .SH AUTHOR The Syncthing Authors .SH COPYRIGHT 2014-2019, The Syncthing Authors .\" Generated by docutils manpage writer. .