summaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
Diffstat (limited to 'doc')
-rw-r--r--doc/index.html10
-rw-r--r--doc/s6-tcpserver-access.html28
-rw-r--r--doc/s6-tcpserver-socketbinder.html (renamed from doc/s6-tcpserver4-socketbinder.html)40
-rw-r--r--doc/s6-tcpserver.html124
-rw-r--r--doc/s6-tcpserver4.html137
-rw-r--r--doc/s6-tcpserver6-socketbinder.html82
-rw-r--r--doc/s6-tcpserver6.html136
-rw-r--r--doc/s6-tcpserver6d.html112
-rw-r--r--doc/s6-tcpserverd.html (renamed from doc/s6-tcpserver4d.html)48
-rw-r--r--doc/upgrade.html21
10 files changed, 173 insertions, 565 deletions
diff --git a/doc/index.html b/doc/index.html
index 37da351..8cd5f2e 100644
--- a/doc/index.html
+++ b/doc/index.html
@@ -91,7 +91,7 @@ run-time requirement if you link against its shared version. </li>
<ul>
<li> The current released version of s6-networking is
-<a href="s6-networking-2.5.1.4.tar.gz">2.5.1.4</a>. </li>
+<a href="s6-networking-2.6.0.0.tar.gz">2.6.0.0</a>. </li>
<li> Alternatively, you can checkout a copy of the
<a href="//git.skarnet.org/cgi-bin/cgit.cgi/s6-networking/">s6-networking
git repository</a>:
@@ -143,12 +143,8 @@ relevant page.
<ul>
<li><a href="s6-tcpclient.html">The <tt>s6-tcpclient</tt> program</a></li>
<li><a href="s6-tcpserver.html">The <tt>s6-tcpserver</tt> program</a></li>
-<li><a href="s6-tcpserver4.html">The <tt>s6-tcpserver4</tt> program</a></li>
-<li><a href="s6-tcpserver4-socketbinder.html">The <tt>s6-tcpserver4-socketbinder</tt> program</a></li>
-<li><a href="s6-tcpserver4d.html">The <tt>s6-tcpserver4d</tt> program</a></li>
-<li><a href="s6-tcpserver6.html">The <tt>s6-tcpserver6</tt> program</a></li>
-<li><a href="s6-tcpserver6-socketbinder.html">The <tt>s6-tcpserver6-socketbinder</tt> program</a></li>
-<li><a href="s6-tcpserver6d.html">The <tt>s6-tcpserver6d</tt> program</a></li>
+<li><a href="s6-tcpserver-socketbinder.html">The <tt>s6-tcpserver-socketbinder</tt> program</a></li>
+<li><a href="s6-tcpserverd.html">The <tt>s6-tcpserverd</tt> program</a></li>
</ul>
<h4> UCSPI tools for secure communication (TLS protocol) over TCP </h4>
diff --git a/doc/s6-tcpserver-access.html b/doc/s6-tcpserver-access.html
index 15f4246..4ef3302 100644
--- a/doc/s6-tcpserver-access.html
+++ b/doc/s6-tcpserver-access.html
@@ -35,12 +35,8 @@ just like tcpwrappers' <tt>tcpd</tt> program.
<ul>
<li> s6-tcpserver-access checks it is run under a UCSPI server tool
-such as <a href="s6-tcpserver.html">s6-tcpserver</a>,
- <a href="s6-tcpserver4.html">s6-tcpserver4</a> or
- <a href="s6-tcpserver6.html">s6-tcpserver6</a>, or their
- stripped-down versions
- <a href="s6-tcpserver4d.html">s6-tcpserver4d</a> or
- <a href="s6-tcpserver6d.html">s6-tcpserver6d</a>. </li>
+such as <a href="s6-tcpserver.html">s6-tcpserver</a> or its stripped-down version
+ <a href="s6-tcpserverd.html">s6-tcpserverd</a>. </li>
<li> It checks that the remote end of the connection fits the
accepted criteria defined by the database contained in <em>rulesdir</em>
or <em>rulesfile</em>. If the database tells it to reject the connection,
@@ -59,9 +55,11 @@ its parent:
</p>
<ul>
- <li> PROTO: normally TCP, but could be anything else, like SSL. </li>
+ <li> PROTO: normally TCP, but could be anything else. </li>
+ <li> ${PROTO}LOCALIP: the local address of the socket. </li>
+ <li> ${PROTO}LOCALPORT: the local port of the socket. </li>
<li> ${PROTO}REMOTEIP: the remote address of the socket, i.e. the client's
-IP address. This can be IPv4 or (if the underlying skalibs supports it) IPv6. </li>
+IP address. </li>
<li> ${PROTO}REMOTEPORT: the remote port of the socket. </li>
</ul>
@@ -71,16 +69,14 @@ IP address. This can be IPv4 or (if the underlying skalibs supports it) IPv6. </
</p>
<ul>
- <li> ${PROTO}LOCALIP: set to the local address of the socket. </li>
- <li> ${PROTO}LOCALPORT: set to the local port of the socket. </li>
- <li> ${PROTO}REMOTEINFO: normally unset, but set to the information
-retrieved from ${PROTO}REMOTEIP via the IDENT protocol if the <tt>-r</tt>
-option has been given. </li>
<li> ${PROTO}REMOTEHOST: set to the remote host name obtained from
a DNS lookup. Unset if the <tt>-H</tt> option has been given. </li>
<li> ${PROTO}LOCALHOST: set to the local host name obtained from a
DNS lookup. If the <tt>-l</tt> option has been given, set to
<em>localname</em> instead. </li>
+ <li> ${PROTO}REMOTEINFO: normally unset, but set to the information
+retrieved from ${PROTO}REMOTEIP via the IDENT protocol if the <tt>-r</tt>
+option has been given. </li>
</ul>
<p>
@@ -227,12 +223,6 @@ environment modifications, if any, s6-tcpserver-access execs into
<h2> Notes </h2>
<ul>
- <li> s6-tcpserver-access works with
-<a href="s6-tcpserver4d.html">s6-tcpserver4d</a>, handling IPv4 addresses,
-as well as
-<a href="s6-tcpserver6d.html">s6-tcpserver6d</a>, handling IPv6 addresses.
-It will automatically detect the remote address type and match it against the
-correct subdatabase. </li>
<li> s6-tcpserver-access may perform several DNS queries. For efficiency
purposes, it does as many of them as possible in parallel. However, if asked
to do an IDENT query, it does not parallelize it with DNS queries. Take
diff --git a/doc/s6-tcpserver4-socketbinder.html b/doc/s6-tcpserver-socketbinder.html
index 6bf1c58..8e7135d 100644
--- a/doc/s6-tcpserver4-socketbinder.html
+++ b/doc/s6-tcpserver-socketbinder.html
@@ -3,9 +3,9 @@
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta http-equiv="Content-Language" content="en" />
- <title>s6-networking: the s6-tcpserver4-socketbinder program</title>
- <meta name="Description" content="s6-networking: the s6-tcpserver4-socketbinder program" />
- <meta name="Keywords" content="s6-networking s6-tcpserver4-socketbinder tcpserver ucspi inet ipv4 socket bind listen" />
+ <title>s6-networking: the s6-tcpserver-socketbinder program</title>
+ <meta name="Description" content="s6-networking: the s6-tcpserver-socketbinder program" />
+ <meta name="Keywords" content="s6-networking s6-tcpserver-socketbinder tcpserver ucspi inet ipv4 ipv6 socket bind listen TCP/IP" />
<!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> -->
</head>
<body>
@@ -16,22 +16,22 @@
<a href="//skarnet.org/">skarnet.org</a>
</p>
-<h1> The <tt>s6-tcpserver4-socketbinder</tt> program </h1>
+<h1> The <tt>s6-tcpserver-socketbinder</tt> program </h1>
<p>
-<tt>s6-tcpserver4-socketbinder</tt> binds an INET domain
-socket to an IPv4 address and port, then executes a program.
+<tt>s6-tcpserver-socketbinder</tt> binds an INET domain
+socket to an IPv4 or IPv6 address and port, then executes a program.
</p>
<h2> Interface </h2>
<pre>
- s6-tcpserver4-socketbinder [ -d | -D ] [ -b <em>backlog</em> ] [ -M | -m ] [ -B ] <em>ip</em> <em>port</em> <em>prog...</em>
+ s6-tcpserver-socketbinder [ -d | -D ] [ -b <em>backlog</em> ] [ -M | -m ] [ -B ] <em>ip</em> <em>port</em> <em>prog...</em>
</pre>
<ul>
- <li> s6-tcpserver4-socketbinder creates a TCP socket
-and binds it to IPv4 address <em>ip</em>, port <em>port</em>.
+ <li> s6-tcpserver-socketbinder creates a TCP socket
+and binds it to IP address <em>ip</em>, port <em>port</em>.
It prepares the socket to accept connections by calling
<a href="https://pubs.opengroup.org/onlinepubs/9699919799/functions/listen.html">listen()</a>. </li>
<li> It then execs into <em>prog...</em> with the open socket
@@ -48,15 +48,15 @@ and is generally used with server programs. This is the default. </li>
<li> <tt>-D</tt>&nbsp;: disallow instant rebinding to the same path. </li>
<li> <tt>-b&nbsp;<em>backlog</em></tt>&nbsp;: set a maximum of
<em>backlog</em> backlog connections on the socket - extra
-connection attempts will rejected by the kernel. The default is SOMAXCONN,
-i.e. the maximum number allowed by the system. If <em>backlog</em>
+connection attempts will rejected by the kernel. The default is the maximum
+number allowed by the system. If <em>backlog</em>
is 0, then the socket will be created, but it <strong>will not be
listening</strong>. </li>
<li> <tt>-M</tt>&nbsp;: create a TCP socket. This is the default. </li>
<li> <tt>-m</tt>&nbsp;: create a UDP socket. Note
that by default UDP sockets are not connection-mode, and <tt>listen()</tt>
will fail - so you should always give the <tt>-b0</tt> option to
-s6-tcpserver4-socketbinder along with <tt>-m</tt>. </li>
+s6-tcpserver-socketbinder along with <tt>-m</tt>. </li>
<li> <tt>-B</tt>&nbsp;: create a blocking socket. Default is non-blocking. </li>
</ul>
@@ -64,18 +64,22 @@ s6-tcpserver4-socketbinder along with <tt>-m</tt>. </li>
<ul>
<li> The socket is provided <strong>non-blocking by default</strong>. </li>
- <li> s6-tcpserver4-socketbinder is part of a set of basic blocks used to
-build a flexible TCP/IPv4 super-server. It normally should be given a
+ <li> s6-tcpserver-socketbinder is part of a set of basic blocks used to
+build a flexible TCP/IP super-server. It normally should be given a
command line crafted to make it execute into
-<a href="s6-tcpserver4d.html">s6-tcpserver4d</a> to accept connections
+<a href="s6-tcpserverd.html">s6-tcpserverd</a> to accept connections
from clients, or into a program such as
<a href="//skarnet.org/software/s6/s6-applyuidgid.html">s6-applyuidgid</a>
to drop privileges before doing so. </li>
- <li> The <a href="s6-tcpserver4.html">s6-tcpserver4</a> program does
+ <li> The <a href="s6-tcpserver.html">s6-tcpserver</a> program does
exactly this. It implements
-a full TCP/IPv4 super-server by building a command line starting with
-s6-tcpserver4-socketbinder and ending with s6-tcpserver4d followed by the
+a full TCP/IP super-server by building a command line starting with
+s6-tcpserver-socketbinder and ending with s6-tcpserverd followed by the
application program, and executing into it. </li>
+ <li> For s6-tcpserver-socketbinder, <tt>::</tt> means "all IPv6 addresses",
+and <tt>0.0.0.0</tt> means "all IPv4 addresses". It does not provide a way
+to bind a socket to all addresses regardless of protocol; instead, you
+should use two sockets, one for IPv4 and one for IPv6. </li>
</ul>
</body>
diff --git a/doc/s6-tcpserver.html b/doc/s6-tcpserver.html
index 362dbf5..561c00f 100644
--- a/doc/s6-tcpserver.html
+++ b/doc/s6-tcpserver.html
@@ -5,7 +5,7 @@
<meta http-equiv="Content-Language" content="en" />
<title>s6-networking: the s6-tcpserver program</title>
<meta name="Description" content="s6-networking: the s6-tcpserver program" />
- <meta name="Keywords" content="s6-networking s6-tcpserver tcpserver ucspi tcp server super-server" />
+ <meta name="Keywords" content="s6-networking s6-tcpserver tcpserver ucspi tcp server super-server ip ipv4 ipv6 TCP/IP" />
<!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> -->
</head>
<body>
@@ -22,51 +22,119 @@
<tt>s6-tcpserver</tt> is an
<a href="https://cr.yp.to/proto/ucspi.txt">UCSPI tool</a> for
TCP connections, i.e. a super-server. It accepts connections from
-clients, and forks a program to handle each connection.
+clients, and spawns a program to handle each connection.
</p>
<h2> Interface </h2>
<pre>
- s6-tcpserver [ -q | -Q | -v ] [ -4 | -6 ] [ -1 ] [ -c <em>maxconn</em> ] [ -C <em>localmaxconn</em> ] [ -b <em>backlog</em> ] [ -G <em>gidlist</em> ] [ -g <em>gid</em> ] [ -u <em>uid</em> ] [ -U ] <em>ip</em> <em>port</em> <em>prog...</em>
+ s6-tcpserver [ -q | -Q | -v ] [ -1 ] [ -c <em>maxconn</em> ] [ -C <em>localmaxconn</em> ] [ -b <em>backlog</em> ] [ -G <em>gidlist</em> ] [ -g <em>gid</em> ] [ -u <em>uid</em> ] [ -U ] <em>ip</em> <em>port</em> <em>prog...</em>
</pre>
<ul>
- <li> s6-tcpserver executes into
-<a href="s6-tcpserver4.html">s6-tcpserver4</a> or
-<a href="s6-tcpserver6.html">s6-tcpserver6</a> depending on whether
-<em>ip</em> is an IPv4 or IPv6 address. It modifies some of its
-option syntax to match s6-tcpserver4 and s6-tcpserver6's.</li>
- <li> s6-tcpserver4 or s6-tcpserver6 handles the connection itself. </li>
+ <li> s6-tcpserver binds to local IP address <em>ip</em> (which can be
+IPv4 or IPv6), port <em>port</em>. </li>
+ <li> It closes its stdin and stdout. </li>
+ <li> For every TCP connection to this address and port, it spawns a
+<em>prog...</em> child with stdin reading from the network socket and
+stdout writing to it. </li>
+ <li> Depending on the verbosity level, it logs what it does to stderr. </li>
+ <li> It runs until killed by a signal. Depending on the received
+signal, it may kill its children before exiting. </li>
+</ul>
+
+<h2> Environment variables </h2>
+
+<p>
+ For each connection, an instance of <em>prog...</em> is spawned with
+the following variables set:
+</p>
+
+<ul>
+ <li> PROTO: always set to TCP </li>
+ <li> TCPLOCALIP: set to the server's address </li>
+ <li> TCPLOCALPORT: set to the server's port </li>
+ <li> TCPREMOTEIP: set to the client's address </li>
+ <li> TCPREMOTEPORT: set to the client's port </li>
+ <li> TCPCONNNUM: set to the number of connections originating from
+the same IP address </li>
</ul>
<h2> Options </h2>
<ul>
- <li> <tt>-q</tt>&nbsp;: be quiet. This is converted into <tt>-v&nbsp;0</tt>
-for s6-tcpserver4 or s6-tcpserver6. </li>
- <li> <tt>-Q</tt>&nbsp;: be normally quiet. This is converted into <tt>-v&nbsp;1</tt>
-for s6-tcpserver4 or s6-tcpserver6. This is the default. </li>
- <li> <tt>-v</tt>&nbsp;: be verbose. This is converted into <tt>-v&nbsp;2</tt>
-for s6-tcpserver4 or s6-tcpserver6. </li>
- <li> <tt>-4</tt>&nbsp;: IPv4 only. Interpret <em>ip</em> as IPv4; if it is
-invalid, exit 100. </li>
- <li> <tt>-6</tt>&nbsp;: IPv6 only. Interpret <em>ip</em> as IPv6; if it is
-invalid, exit 100. If neither the <tt>-4</tt> nor the <tt>-6</tt> option is
-given, s6-tcpserver will parse <em>ip</em> to determine its family. </li>
- <li> Every other option is passed verbatim to s6-tcpserver4 or s6-tcpserver6. </li>
+ <li> <tt>-q</tt>&nbsp;: be quiet. Only print fatal error messages to stderr. </li>
+ <li> <tt>-Q</tt>&nbsp;: be normally quiet. Print warnings and fatal
+error messages to stderr. This is the default. </li>
+ <li> <tt>-v</tt>&nbsp;: be verbose. Additionally to fatal errors and
+warnings, also print status and connection information for every client. </li>
+ <li> <tt>-1</tt>&nbsp;: write <em>port</em> to stdout, before
+closing it, right after binding and listening to the network socket.
+If stdout is suitably redirected, this can be used by monitoring
+programs to check when the server is ready to accept connections. </li>
+ <li> <tt>-c&nbsp;<em>maxconn</em></tt>&nbsp;: accept at most
+<em>maxconn</em> concurrent connections. Default is 40. It is
+impossible to set it higher than 1000. </li>
+ <li> <tt>-C&nbsp;<em>localmaxconn</em></tt>&nbsp;: accept at most
+<em>localmaxconn</em> connections from the same IP address.
+Default is 40. It is impossible to set it higher than <em>maxconn</em>. </li>
+ <li> <tt>-b&nbsp;<em>backlog</em></tt>&nbsp;: set a maximum of
+<em>backlog</em> backlog connections on the socket. Extra
+connection attempts will rejected by the kernel. </li>
+ <li> <tt>-G&nbsp;<em>gidlist</em></tt>&nbsp;: change s6-tcpserver's
+supplementary group list to <em>gidlist</em> after binding the socket.
+This is only valid when run as root. <em>gidlist</em> must be a
+comma-separated list of numerical group IDs. </li>
+ <li> <tt>-g&nbsp;<em>gid</em></tt>&nbsp;: change s6-tcpserver's group id
+to <em>gid</em> after binding the socket. This is only valid when run
+as root. </li>
+ <li> <tt>-u&nbsp;<em>uid</em></tt>&nbsp;: change s6-tcpserver's user id
+to <em>uid</em> after binding the socket. This is only valid when run
+as root. </li>
+ <li> <tt>-U</tt>&nbsp;: change s6-tcpserver's user id, group id and
+supplementary group list
+according to the values of the UID, GID and GIDLIST environment variables
+after binding the socket. This is only valid when run as root.
+This can be used with the
+<a href="//skarnet.org/software/s6/s6-envuidgid.html">s6-envuidgid</a>
+program to easily script a service that binds to a privileged socket
+then drops its privileges to those of a named non-root account. </li>
+</ul>
+
+<h2> Signals </h2>
+
+<ul>
+ <li> SIGTERM: exit. </li>
+ <li> SIGHUP: send a SIGTERM and a SIGCONT to all children. </li>
+ <li> SIGQUIT: send a SIGTERM and a SIGCONT to all children, then exit. </li>
+ <li> SIGABRT: send a SIGKILL to all children, then exit. </li>
</ul>
<h2> Notes </h2>
<ul>
- <li> s6-tcpserver executes either into s6-tcpserver4, which only serves
-IPv4, or into s6-tcpserver6, which only serves IPv6. It will not bind to every
-available IP address of the machine whether they are v4 or v6; on the
-other hand, it can bind to every available IPv4 address (if <em>ip</em>
-is <tt>0.0.0.0</tt>) or to every available IPv6 address (if <em>ip</em>
-is <tt>::</tt>). Two instances of s6-tcpserver can cover every
-available address. </li>
+ <li> Unlike its ancestor
+<a href="https://cr.yp.to/ucspi-tcp/tcpserver.html">tcpserver</a>,
+s6-tcpserver performs just the bare minimum: the point is to have a
+very small and very fast process to serve connections with the least
+possible overhead. Features such as access control and DNS resolution are
+provided via the <a href="s6-tcpserver-access.html">s6-tcpserver-access</a>
+program. </li>
+ <li> s6-tcpserver is actually a wrapper that rewrites itself into a
+command line running
+ <ul>
+ <li> <a href="s6-tcpserver-socketbinder.html">s6-tcpserver-socketbinder</a>,
+that binds the socket and listens to it </li>
+ <li> <a href="//skarnet.org/software/s6/s6-applyuidgid.html">s6-applyuidgid</a>,
+that drops privileges </li>
+ <li> <a href="s6-tcpserverd.html">s6-tcpserverd</a>, the long-lived process
+that actually accepts the connections. So if you see in your <tt>ps</tt> output
+that the name of the process is <tt>s6-tcpserverd</tt>, that's why. </li>
+ </ul>
+ <li> s6-tcpserver treats IPv4 and IPv6 separately. If you want to listen on
+<em>all</em> the addresses of a machine no matter whether v4 or v6, then you
+need to run <em>two</em> s6-tcpserver processes: one on <tt>0.0.0.0</tt> and
+and one on <tt>::</tt>. </li>
</ul>
</body>
diff --git a/doc/s6-tcpserver4.html b/doc/s6-tcpserver4.html
deleted file mode 100644
index bc1bd5e..0000000
--- a/doc/s6-tcpserver4.html
+++ /dev/null
@@ -1,137 +0,0 @@
-<html>
- <head>
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
- <meta http-equiv="Content-Language" content="en" />
- <title>s6-networking: the s6-tcpserver4 program</title>
- <meta name="Description" content="s6-networking: the s6-tcpserver4 program" />
- <meta name="Keywords" content="s6-networking s6-tcpserver4 tcpserver ucspi tcp server super-server ipv4" />
- <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> -->
- </head>
-<body>
-
-<p>
-<a href="index.html">s6-networking</a><br />
-<a href="//skarnet.org/software/">Software</a><br />
-<a href="//skarnet.org/">skarnet.org</a>
-</p>
-
-<h1> The <tt>s6-tcpserver4</tt> program </h1>
-
-<p>
-<tt>s6-tcpserver4</tt> is a super-server for IPv4 TCP
-connections. It accepts connections from clients, and forks a
-program to handle each connection.
-</p>
-
-<h2> Interface </h2>
-
-<pre>
- s6-tcpserver4 [ -1 ] [ -v <em>verbosity</em> ] [ -c <em>maxconn</em> ] [ -C <em>localmaxconn</em> ] [ -b <em>backlog</em> ] [ -G <em>gidlist</em> ] [ -g <em>gid</em> ] [ -u <em>uid</em> ] [ -U ] <em>ip</em> <em>port</em> <em>prog...</em>
-</pre>
-
-<ul>
- <li> s6-tcpserver4 binds to local IPv4 address <em>ip</em>,
-port <em>port</em>. </li>
- <li> It closes its stdin and stdout. </li>
- <li> For every TCP connection to this address and port, it
-forks. The child sets some environment variables, then
-executes <em>prog...</em> with stdin reading from the network
-socket and stdout writing to it. </li>
- <li> Depending on the verbosity level, it logs what it does to stderr. </li>
- <li> It runs until killed by a signal. Depending on the received
-signal, it may kill its children before exiting. </li>
- <li> s6-tcpserver4 actually doesn't do any of this itself. It is
-a wrapper, rewriting the command line and executing into a chain
-of programs that perform those duties. </li>
-</ul>
-
-<h2> Environment variables </h2>
-
-<p>
- For each connection, an instance of <em>prog...</em> is spawned with
-the following variables set:
-</p>
-
-<ul>
- <li> PROTO: always set to TCP </li>
- <li> TCPREMOTEIP: set to the originating address </li>
- <li> TCPREMOTEPORT: set to the originating port </li>
- <li> TCPCONNNUM: set to the number of connections originating from
-the same IP address </li>
-</ul>
-
-<h2> Options </h2>
-
-<ul>
- <li> <tt>-1</tt>&nbsp;: write <em>port</em> to stdout, before
-closing it, right after binding and listening to the network socket.
-If stdout is suitably redirected, this can be used by monitoring
-programs to check when the server is ready to accept connections. </li>
- <li> <tt>-v&nbsp;<em>verbosity</em></tt>&nbsp;: be more or less verbose.
-By default, <em>verbosity</em> is 1: print warning messages to stderr.
-0 means only print fatal error messages ; 2 means print status and
-connection information for every client. </li>
- <li> <tt>-c&nbsp;<em>maxconn</em></tt>&nbsp;: accept at most
-<em>maxconn</em> concurrent connections. Default is 40. It is
-impossible to set it higher than 1000. </li>
- <li> <tt>-C&nbsp;<em>localmaxconn</em></tt>&nbsp;: accept at most
-<em>localmaxconn</em> connections from the same IP address.
-Default is 40. It is impossible to set it higher than <em>maxconn</em>. </li>
- <li> <tt>-b&nbsp;<em>backlog</em></tt>&nbsp;: set a maximum of
-<em>backlog</em> backlog connections on the socket. Extra
-connection attempts will rejected by the kernel. </li>
- <li> <tt>-G&nbsp;<em>gidlist</em></tt>&nbsp;: change s6-tcpserver4's
-supplementary group list to <em>gidlist</em> after binding the socket.
-This is only valid when run as root. <em>gidlist</em> must be a
-comma-separated list of numerical group IDs. </li>
- <li> <tt>-g&nbsp;<em>gid</em></tt>&nbsp;: change s6-tcpserver4's group id
-to <em>gid</em> after binding the socket. This is only valid when run
-as root. </li>
- <li> <tt>-u&nbsp;<em>uid</em></tt>&nbsp;: change s6-tcpserver4's user id
-to <em>uid</em> after binding the socket. This is only valid when run
-as root. </li>
- <li> <tt>-U</tt>&nbsp;: change s6-tcpserver4's user id, group id and
-supplementary group list
-according to the values of the UID, GID and GIDLIST environment variables
-after binding the socket. This is only valid when run as root.
-This can be used with the
-<a href="//skarnet.org/software/s6/s6-envuidgid.html">s6-envuidgid</a>
-program to easily script a service that binds to a privileged socket
-then drops its privileges to those of a named non-root account. </li>
-</ul>
-
-<h2> Signals </h2>
-
-<ul>
- <li> SIGTERM: exit. </li>
- <li> SIGHUP: send a SIGTERM and a SIGCONT to all children. </li>
- <li> SIGQUIT: send a SIGTERM and a SIGCONT to all children, then exit. </li>
- <li> SIGABRT: send a SIGKILL to all children, then exit. </li>
-</ul>
-
-<h2> Notes </h2>
-
-<ul>
- <li> Unlike its ancestor
-<a href="https://cr.yp.to/ucspi-tcp/tcpserver.html">tcpserver</a>,
-s6-tcpserver4 performs just the bare minimum: the point is to have a
-very small and very fast process to serve connections with the least
-possible overhead. Features such as additional environment variables,
-access control and DNS resolution are provided
-via the <a href="s6-tcpserver-access.html">s6-tcpserver-access</a>
-program. </li>
- <li> In previous releases of s6-networking, s6-tcpserver4 was
-monolithic: it did the work of
-<a href="s6-tcpserver4-socketbinder.html">s6-tcpserver4-socketbinder</a>,
-<a href="//skarnet.org/software/s6/s6-applyuidgid.html">s6-applyuidgid</a> and
-<a href="s6-tcpserver4d.html">s6-tcpserver4d</a> itself. The functionality has now
-been split into several different programs because some service startup
-schemes require the daemon to get its socket from an external
-program instead of creating and binding it itself. The most obvious
-application of this is upgrading a long-lived process without
-losing existing connections. </li>
-</ul>
-
-</body>
-</html>
diff --git a/doc/s6-tcpserver6-socketbinder.html b/doc/s6-tcpserver6-socketbinder.html
deleted file mode 100644
index 5bb2ae5..0000000
--- a/doc/s6-tcpserver6-socketbinder.html
+++ /dev/null
@@ -1,82 +0,0 @@
-<html>
- <head>
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
- <meta http-equiv="Content-Language" content="en" />
- <title>s6-networking: the s6-tcpserver6-socketbinder program</title>
- <meta name="Description" content="s6-networking: the s6-tcpserver6-socketbinder program" />
- <meta name="Keywords" content="s6-networking s6-tcpserver6-socketbinder tcpserver ucspi inet ipv6 socket bind listen" />
- <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> -->
- </head>
-<body>
-
-<p>
-<a href="index.html">s6-networking</a><br />
-<a href="//skarnet.org/software/">Software</a><br />
-<a href="//skarnet.org/">skarnet.org</a>
-</p>
-
-<h1> The <tt>s6-tcpserver6-socketbinder</tt> program </h1>
-
-<p>
-<tt>s6-tcpserver6-socketbinder</tt> binds an INET domain
-socket to an IPv6 address and port, then executes a program.
-</p>
-
-<h2> Interface </h2>
-
-<pre>
- s6-tcpserver6-socketbinder [ -d | -D ] [ -b <em>backlog</em> ] [ -M | -m ] [ -B ] <em>ip</em> <em>port</em> <em>prog...</em>
-</pre>
-
-<ul>
- <li> s6-tcpserver6-socketbinder creates an TCP socket
-and binds it to IPv6 address <em>ip</em>, port <em>port</em>.
-It prepares the socket to accept connections by calling
-<a href="https://pubs.opengroup.org/onlinepubs/9699919799/functions/listen.html">listen()</a>. </li>
- <li> It then execs into <em>prog...</em> with the open socket
-as its standard input. </li>
-</ul>
-
-<h2> Options </h2>
-
-<ul>
- <li> <tt>-d</tt>&nbsp;: allow instant rebinding to the same IP and port
-even if it has been used not long ago - this is the SO_REUSEADDR flag to
-<a href="https://pubs.opengroup.org/onlinepubs/9699919799/functions/setsockopt.html">setsockopt()</a>
-and is generally used with server programs. This is the default. </li>
- <li> <tt>-D</tt>&nbsp;: disallow instant rebinding to the same path. </li>
- <li> <tt>-b&nbsp;<em>backlog</em></tt>&nbsp;: set a maximum of
-<em>backlog</em> backlog connections on the socket - extra
-connection attempts will rejected by the kernel. The default is SOMAXCONN,
-i.e. the maximum number allowed by the system. If <em>backlog</em>
-is 0, then the socket will be created, but it <strong>will not be
-listening</strong>. </li>
- <li> <tt>-M</tt>&nbsp;: create a TCP socket. This is the default. </li>
- <li> <tt>-m</tt>&nbsp;: create a UDP socket. Note
-that by default UDP sockets are not connection-mode, and <tt>listen()</tt>
-will fail - so you should always give the <tt>-b0</tt> option to
-s6-tcpserver6-socketbinder along with <tt>-m</tt>. </li>
- <li> <tt>-B</tt>&nbsp;: create a blocking socket. Default is non-blocking. </li>
-</ul>
-
-<h2> Notes </h2>
-
-<ul>
- <li> The socket is provided <strong>non-blocking by default</strong>. </li>
- <li> s6-tcpserver6-socketbinder is part of a set of basic blocks used to
-build a flexible TCP/IPv6 super-server. It normally should be given a
-command line crafted to make it execute into
-<a href="s6-tcpserver6d.html">s6-tcpserver6d</a> to accept connections
-from clients, or into a program such as
-<a href="//skarnet.org/software/s6/s6-applyuidgid.html">s6-applyuidgid</a>
-to drop privileges before doing so. </li>
- <li> The <a href="s6-tcpserver6.html">s6-tcpserver6</a> program does
-exactly this. It implements
-a full TCP/IPv6 super-server by building a command line starting with
-s6-tcpserver6-socketbinder and ending with s6-tcpserver6d followed by the
-application program, and executing into it. </li>
-</ul>
-
-</body>
-</html>
diff --git a/doc/s6-tcpserver6.html b/doc/s6-tcpserver6.html
deleted file mode 100644
index 01be274..0000000
--- a/doc/s6-tcpserver6.html
+++ /dev/null
@@ -1,136 +0,0 @@
-<html>
- <head>
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
- <meta http-equiv="Content-Language" content="en" />
- <title>s6-networking: the s6-tcpserver6 program</title>
- <meta name="Description" content="s6-networking: the s6-tcpserver6 program" />
- <meta name="Keywords" content="s6-networking s6-tcpserver6 tcpserver ucspi tcp server super-server ipv6" />
- <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> -->
- </head>
-<body>
-
-<p>
-<a href="index.html">s6-networking</a><br />
-<a href="//skarnet.org/software/">Software</a><br />
-<a href="//skarnet.org/">skarnet.org</a>
-</p>
-
-<h1> The <tt>s6-tcpserver6</tt> program </h1>
-
-<p>
-<tt>s6-tcpserver6</tt> is a super-server for IPv6 TCP
-connections. It accepts connections from clients, and forks a
-program to handle each connection.
-</p>
-
-<h2> Interface </h2>
-
-<pre>
- s6-tcpserver6 [ -1 ] [ -v <em>verbosity</em> ] [ -c <em>maxconn</em> ] [ -C <em>localmaxconn</em> ] [ -b <em>backlog</em> ] [ -G <em>gidlist</em> ] [ -g <em>gid</em> ] [ -u <em>uid</em> ] [ -U ] <em>ip</em> <em>port</em> <em>prog...</em>
-</pre>
-
-<ul>
- <li> s6-tcpserver6 binds to local IPv6 address <em>ip</em>,
-port <em>port</em>. </li>
- <li> It closes its stdin and stdout. </li>
- <li> For every TCP connection to this address and port, it
-forks. The child sets some environment variables, then
-executes <em>prog...</em> with stdin reading from the network socket
-and stdout writing to it. </li>
- <li> Depending on the verbosity level, it logs what it does to stderr. </li>
- <li> It runs until killed by a signal. Depending on the received
-signal, it may kill its children before exiting. </li>
- <li> s6-tcpserver6 actually doesn't do any of this itself. It is
-a wrapper, rewriting the command line and executing into a chain
-of programs that perform those duties. </li>
-</ul>
-
-<h2> Environment variables </h2>
-
-<p>
- For each connection, an instance of <em>prog...</em> is spawned with
-the following variables set:
-</p>
-
-<ul>
- <li> PROTO: always set to TCP </li>
- <li> TCPREMOTEIP: set to the originating address, in canonical IPv6 form </li>
- <li> TCPREMOTEPORT: set to the originating port </li>
- <li> TCPCONNNUM: set to the number of connections originating from
-the same IPv6 address </li>
-</ul>
-
-<h2> Options </h2>
-
-<ul>
- <li> <tt>-1</tt>&nbsp;: write <em>port</em> to stdout, before
-closing it, right after binding and listening to the network socket.
-If stdout is suitably redirected, this can be used by monitoring
-programs to check when the server is ready to accept connections. </li>
- <li> <tt>-v&nbsp;<em>verbosity</em></tt>&nbsp;: be more or less verbose.
-By default, <em>verbosity</em> is 1: print warning messages to stderr.
-0 means only print fatal error messages ; 2 means print status and
-connection information for every client. </li>
- <li> <tt>-c&nbsp;<em>maxconn</em></tt>&nbsp;: accept at most
-<em>maxconn</em> concurrent connections. Default is 40. It is
-impossible to set it higher than 1000. </li>
- <li> <tt>-C&nbsp;<em>localmaxconn</em></tt>&nbsp;: accept at most
-<em>localmaxconn</em> connections from the same IP address.
-Default is 40. It is impossible to set it higher than <em>maxconn</em>. </li>
- <li> <tt>-b&nbsp;<em>backlog</em></tt>&nbsp;: set a maximum of
-<em>backlog</em> backlog connections on the socket. Extra
-connection attempts will rejected by the kernel. </li>
- <li> <tt>-G&nbsp;<em>gidlist</em></tt>&nbsp;: change s6-tcpserver6's
-supplementary group list to <em>gidlist</em> after binding the socket.
-This is only valid when run as root. <em>gidlist</em> must be a
-comma-separated list of numerical group IDs. </li>
- <li> <tt>-g&nbsp;<em>gid</em></tt>&nbsp;: change s6-tcpserver6's group id
-to <em>gid</em> after binding the socket. This is only valid when run
-as root. </li>
- <li> <tt>-u&nbsp;<em>uid</em></tt>&nbsp;: change s6-tcpserver6's user id
-to <em>uid</em> after binding the socket. This is only valid when run
-as root. </li>
- <li> <tt>-U</tt>&nbsp;: change s6-tcpserver6's user id, group id and
-supplementary group list
-according to the values of the UID, GID and GIDLIST environment variables
-after binding the socket. This is only valid when run as root.
-This can be used with the
-<a href="//skarnet.org/software/s6/s6-envuidgid.html">s6-envuidgid</a>
-program to easily script a service that binds to a privileged socket
-then drops its privileges to those of a named non-root account. </li>
-</ul>
-
-<h2> Signals </h2>
-
-<ul>
- <li> SIGTERM: exit. </li>
- <li> SIGHUP: send a SIGTERM and a SIGCONT to all children. </li>
- <li> SIGQUIT: send a SIGTERM and a SIGCONT to all children, then exit. </li>
- <li> SIGABRT: send a SIGKILL to all children, then exit. </li>
-</ul>
-
-<h2> Notes </h2>
-
-<ul>
- <li> s6-tcpserver6 will only serve real IPv6 addresses; it does not
-default to an IPv4 address. The
-<a href="s6-tcpserver4.html">s6-tcpserver4</a> program should be
-used to serve IPv4 addresses. </li>
- <li> s6-tcpserver6 will only work if the underlying
-<a href="//skarnet.org/software/skalibs/">skalibs</a> has
-been compiled with IPv6 support. </li>
- <li> In previous releases of s6-networking, s6-tcpserver6 was
-monolithic: it did the work of
-<a href="s6-tcpserver6-socketbinder.html">s6-tcpserver6-socketbinder</a>,
-<a href="//skarnet.org/software/s6/s6-applyuidgid.html">s6-applyuidgid</a> and
-<a href="s6-tcpserver6d.html">s6-tcpserver6d</a> itself. The functionality has now
-been split into several different programs because some service startup
-schemes require the daemon to get its socket from an external
-program instead of creating and binding it itself. The most obvious
-application of this is upgrading a long-lived process without
-losing existing connections. </li>
-</ul>
-
-</body>
-</html>
diff --git a/doc/s6-tcpserver6d.html b/doc/s6-tcpserver6d.html
deleted file mode 100644
index 585fa41..0000000
--- a/doc/s6-tcpserver6d.html
+++ /dev/null
@@ -1,112 +0,0 @@
-<html>
- <head>
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
- <meta http-equiv="Content-Language" content="en" />
- <title>s6-networking: the s6-tcpserver6d program</title>
- <meta name="Description" content="s6-networking: the s6-tcpserver6d program" />
- <meta name="Keywords" content="s6-networking s6-tcpserver6d tcpserver ucspi tcp server super-server ipv6" />
- <!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> -->
- </head>
-<body>
-
-<p>
-<a href="index.html">s6-networking</a><br />
-<a href="//skarnet.org/software/">Software</a><br />
-<a href="//skarnet.org/">skarnet.org</a>
-</p>
-
-<h1> The <tt>s6-tcpserver6d</tt> program </h1>
-
-<p>
-<tt>s6-tcpserver6d</tt> is the serving part of the
-<a href="s6-tcpserver6.html">s6-tcpserver6</a> super-server.
-It assumes that its stdin is a bound and listening TCP/IPv6 socket,
-and it accepts connections from clients connecting to it,
-forking a program to handle each connection.
-</p>
-
-<h2> Interface </h2>
-
-<pre>
- s6-tcpserver6d [ -1 ] [ -v <em>verbosity</em> ] [ -c <em>maxconn</em> ] [ -C <em>localmaxconn</em> ] <em>prog...</em>
-</pre>
-
-<ul>
- <li> s6-tcpserver6d accepts connections from clients to an already
-bound and listening TCP socket which is its standard input. </li>
- <li> For every TCP connection to this socket, it
-forks. The child sets some environment variables, then
-executes <em>prog...</em> with stdin reading from the network
-socket and stdout writing to it. </li>
- <li> Depending on the verbosity level, it logs what it does to stderr. </li>
- <li> It runs until killed by a signal. Depending on the received
-signal, it may kill its children before exiting. </li>
-</ul>
-
-<h2> Environment variables </h2>
-
-<p>
- For each connection, an instance of <em>prog...</em> is spawned with
-the following variables set:
-</p>
-
-<ul>
- <li> PROTO: always set to TCP </li>
- <li> TCPREMOTEIP: set to the originating address </li>
- <li> TCPREMOTEPORT: set to the originating port </li>
- <li> TCPCONNNUM: set to the number of connections originating from
-the same IP address </li>
-</ul>
-
-<h2> Options </h2>
-
-<ul>
- <li> <tt>-1</tt>&nbsp;: write a newline to stdout, and close stdout,
-right before entering the client-accepting loop.
-If stdout is suitably redirected, this can be used by monitoring
-programs to check when the server is accepting connections, for instance
-s6's <a href="//skarnet.org/software/s6/notifywhenup.html">readiness
-notification mechanism</a>. </li>
- <li> <tt>-v&nbsp;<em>verbosity</em></tt>&nbsp;: be more or less verbose.
-By default, <em>verbosity</em> is 1: print warning messages to stderr.
-0 means only print fatal error messages ; 2 means print status and
-connection information for every client. </li>
- <li> <tt>-c&nbsp;<em>maxconn</em></tt>&nbsp;: accept at most
-<em>maxconn</em> concurrent connections. Default is 40. It is
-impossible to set it higher than 1000. </li>
- <li> <tt>-C&nbsp;<em>localmaxconn</em></tt>&nbsp;: accept at most
-<em>localmaxconn</em> connections from the same IP address.
-Default is 40. It is impossible to set it higher than <em>maxconn</em>. </li>
-</ul>
-
-<h2> Signals </h2>
-
-<ul>
- <li> SIGTERM: exit. </li>
- <li> SIGHUP: send a SIGTERM and a SIGCONT to all children. </li>
- <li> SIGQUIT: send a SIGTERM and a SIGCONT to all children, then exit. </li>
- <li> SIGABRT: send a SIGKILL to all children, then exit. </li>
-</ul>
-
-<h2> Notes </h2>
-
-<ul>
- <li> Unlike its ancestor
-<a href="https://cr.yp.to/ucspi-tcp/tcpserver.html">tcpserver</a>,
-s6-tcpserver6d performs just the bare minimum: the point is to have a
-very small and very fast process to serve connections with the least
-possible overhead. Features such as additional environment variables,
-access control and DNS resolution are provided
-via the <a href="s6-tcpserver-access.html">s6-tcpserver-access</a>
-program. </li>
- <li> s6-tcpserver6d is meant to be execve'd into by a program that gets
-the listening socket. That program is normally
-<a href="s6-tcpserver6-socketbinder.html">s6-tcpserver6-socketbinder</a>,
-which creates the socket itself; but it can be a different one if the
-socket is to be retrieved by another means, for instance by fd-passing
-from a fd-holding daemon (some people call this "socket activation"). </li>
-</ul>
-
-</body>
-</html>
diff --git a/doc/s6-tcpserver4d.html b/doc/s6-tcpserverd.html
index a11bae1..6600a7b 100644
--- a/doc/s6-tcpserver4d.html
+++ b/doc/s6-tcpserverd.html
@@ -3,9 +3,9 @@
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta http-equiv="Content-Language" content="en" />
- <title>s6-networking: the s6-tcpserver4d program</title>
- <meta name="Description" content="s6-networking: the s6-tcpserver4d program" />
- <meta name="Keywords" content="s6-networking s6-tcpserver4d tcpserver ucspi tcp server super-server ipv4" />
+ <title>s6-networking: the s6-tcpserverd program</title>
+ <meta name="Description" content="s6-networking: the s6-tcpserverd program" />
+ <meta name="Keywords" content="s6-networking s6-tcpserverd tcpserver ucspi tcp server super-server ipv4 ipv6 TCP/IP" />
<!-- <link rel="stylesheet" type="text/css" href="//skarnet.org/default.css" /> -->
</head>
<body>
@@ -16,28 +16,27 @@
<a href="//skarnet.org/">skarnet.org</a>
</p>
-<h1> The <tt>s6-tcpserver4d</tt> program </h1>
+<h1> The <tt>s6-tcpserverd</tt> program </h1>
<p>
-<tt>s6-tcpserver4d</tt> is the serving part of the
-<a href="s6-tcpserver4.html">s6-tcpserver4</a> super-server.
-It assumes that its stdin is a bound and listening TCP/IPv4 socket,
+<tt>s6-tcpserverd</tt> is the serving part of the
+<a href="s6-tcpserver.html">s6-tcpserver</a> super-server.
+It assumes that its stdin is a bound and listening TCP/IP socket,
and it accepts connections from clients connecting to it,
-forking a program to handle each connection.
+spawning a program to handle each connection.
</p>
<h2> Interface </h2>
<pre>
- s6-tcpserver4d [ -1 ] [ -v <em>verbosity</em> ] [ -c <em>maxconn</em> ] [ -C <em>localmaxconn</em> ] <em>prog...</em>
+ s6-tcpserverd [ -1 ] [ -v <em>verbosity</em> ] [ -c <em>maxconn</em> ] [ -C <em>localmaxconn</em> ] <em>prog...</em>
</pre>
<ul>
- <li> s6-tcpserver4d accepts connections from clients to an already
+ <li> s6-tcpserverd accepts connections from clients to an already
bound and listening TCP socket which is its standard input. </li>
<li> For every TCP connection to this socket, it
-forks. The child sets some environment variables, then
-executes <em>prog...</em> with stdin reading from the network
+spawns a <em>prog...</em> child with stdin reading from the network
socket and stdout writing to it. </li>
<li> Depending on the verbosity level, it logs what it does to stderr. </li>
<li> It runs until killed by a signal. Depending on the received
@@ -53,8 +52,10 @@ the following variables set:
<ul>
<li> PROTO: always set to TCP </li>
- <li> TCPREMOTEIP: set to the originating address </li>
- <li> TCPREMOTEPORT: set to the originating port </li>
+ <li> TCPLOCALIP: set to the server socket's address </li>
+ <li> TCPLOCALPORT: set to the server socket's port </li>
+ <li> TCPREMOTEIP: set to the client socket's address </li>
+ <li> TCPREMOTEPORT: set to the client socket's port </li>
<li> TCPCONNNUM: set to the number of connections originating from
the same IP address </li>
</ul>
@@ -62,8 +63,8 @@ the same IP address </li>
<h2> Options </h2>
<ul>
- <li> <tt>-1</tt>&nbsp;: write a newline to stdout, and close stdout,
-right before entering the client-accepting loop.
+ <li> <tt>-1</tt>&nbsp;: write the local port, followed by newline,
+to stdout, and close stdout, right before entering the client-accepting loop.
If stdout is suitably redirected, this can be used by monitoring
programs to check when the server is accepting connections. This can be
used with s6's <a href="//skarnet.org/software/s6/notifywhenup.html">readiness
@@ -75,7 +76,7 @@ By default, <em>verbosity</em> is 1: print warning messages to stderr.
connection information for every client. </li>
<li> <tt>-c&nbsp;<em>maxconn</em></tt>&nbsp;: accept at most
<em>maxconn</em> concurrent connections. Default is 40. It is
-impossible to set it higher than 1000. </li>
+impossible to set it higher than 16384. </li>
<li> <tt>-C&nbsp;<em>localmaxconn</em></tt>&nbsp;: accept at most
<em>localmaxconn</em> connections from the same IP address.
Default is 40. It is impossible to set it higher than <em>maxconn</em>. </li>
@@ -95,15 +96,14 @@ Default is 40. It is impossible to set it higher than <em>maxconn</em>. </li>
<ul>
<li> Unlike its ancestor
<a href="https://cr.yp.to/ucspi-tcp/tcpserver.html">tcpserver</a>,
-s6-tcpserver4d performs just the bare minimum: the point is to have a
-very small and very fast process to serve connections with the least
-possible overhead. Features such as additional environment variables,
-access control and DNS resolution are provided
-via the <a href="s6-tcpserver-access.html">s6-tcpserver-access</a>
+s6-tcpserverd performs just the bare minimum: the point is to have a
+small and very fast process to serve connections with the least
+possible overhead. Features such as access control and DNS resolution
+are provided via the <a href="s6-tcpserver-access.html">s6-tcpserver-access</a>
program. </li>
- <li> s6-tcpserver4d is meant to be execve'd into by a program that gets
+ <li> s6-tcpserverd is meant to be execve'd into by a program that gets
the listening socket. That program is normally
-<a href="s6-tcpserver4-socketbinder.html">s6-tcpserver4-socketbinder</a>,
+<a href="s6-tcpserver-socketbinder.html">s6-tcpserver-socketbinder</a>,
which creates the socket itself; but it can be a different one if the
socket is to be retrieved by another means, for instance by fd-passing
from a fd-holding daemon (some people call this "socket activation"). </li>
diff --git a/doc/upgrade.html b/doc/upgrade.html
index 7b2c27b..0f20319 100644
--- a/doc/upgrade.html
+++ b/doc/upgrade.html
@@ -18,7 +18,7 @@
<h1> What has changed in s6-networking </h1>
-<h2> in 2.5.1.4 </h2>
+<h2> in 2.6.0.0 </h2>
<ul>
<li> <a href="//skarnet.org/software/skalibs/">skalibs</a>
@@ -35,7 +35,24 @@ optional dependency bumped to 1.1.1w </li>
optional dependency bumped to 3.7.0 </li>
<li> <a href="s6-tcpserver-access.html">s6-tcpserver-access</a> does
not print a warning on <tt>-v 2</tt> or more when it is run without
-the <tt>-i</tt> or </tt>-x</tt> option. </li>
+the <tt>-i</tt> or </tt>-x</tt> option. It is not needed anymore in
+order to export TCPLOCALIP and TCPLOCALPORT to the applications. </li>
+ <li> The tcpserver chain has been unified!
+<tt>s6-tcpserver4</tt>, <tt>s6-tcpserver6</tt>,
+<tt>s6-tcpserver4-socketbinder</tt>, <tt>s6-tcpserver6-socketbinder</tt>,
+<tt>s6-tcpserver4d</tt> and <tt>s6-tcpserver6d</tt> have all
+disappeared. Instead, there are just 3 programs:
+ <ul>
+ <li> <a href="s6-tcpserver-socketbinder.html">s6-tcpserver-socketbinder</a>,
+for socket binding </li>
+ <li> <a href="s6-tcpserverd.html">s6-tcpserverd</a>, the long-lived
+process. It now exports TCPLOCALIP and TCPLOCALPORT in addition to PROTO,
+TCPREMOTEIP, TCPREMOTEPORT and TCPCONNNUM. </li>
+ <li> <a href="s6-tcpserver.html">s6-tcpserver</a>, which still has
+the same interface except that the <tt>-4</tt> and <tt>-6</tt> options
+have been removed, and that is still a wrapper around the others. </li>
+ </ul>
+ </li>
</ul>
<h2> in 2.5.1.3 </h2>