LISTEN(8)LISTEN(8)
NAME
listen, listen1, tcp7, tcp9, tcp19, tcp21, tcp23, tcp25, tcp53, tcp110, tcp113, tcp143, tcp445, tcp513, tcp515, tcp564, tcp565, tcp566, tcp567, tcp993, tcp995, tcp1723, tcp17007, tcp17008, tcp17009, tcp17010, tcp17013, tcp17019, tcp17020 – listen for calls on a network device
SYNOPSIS
aux/listen
[-iq]
[-d
srvdir]
[-t
trustsrvdir]
[-n
namespace]
[-p
maxprocs]
[-a
addr]
[proto]
aux/listen1
[
-1tv
]
[-p
maxprocs]
[-n
namespace]
addr
cmd
[
args...
]
DESCRIPTION
Listen
listens on a network for inbound calls to local services.
Proto
is the network protocol on which to listen, by default
tcp.
Incoming calls to any address
*
are accepted unless
addr
is specified with the
-a
option.
The services available are executable, non-empty files in
srvdir
or
trustsrvdir.
If neither
srvdir
nor
trustsrvdir
is given,
listen
looks for executable files in
/bin/service.
Services found in
srvdir
are executed as user
none;
services found in
trustsrvdir
are executed as the user who started
listen.
When changing user to
none,
a new namespace is created,
usually by executing
/lib/namespace,
but
-n
selects an alternate
namespace.
The
-p
option limits the number of processes that
listen
spawns to service the connections. If the
maxprocs
limit is reached,
listen
will log the event and delay servicing until the number
of connection processes drops below the limit again. A
maxprocs
smaller or equal zero means no limit (default).
Option
-q
suppresses affirmative log information.
Option
-i
suppresses the periodic scan of the service directories for changes.
Service names are made by concatenating the name of
the network with the name of the service or port.
For example,
an inbound call on the TCP network for port 565 executes service
tcp565.
At least the following services are available in
/bin/service.
tcp564
serve a piece of the name space using the Plan 9 file system protocol,
with authentication via
Tauth
(in
attach(5)),
no encryption,
and multiplex multiple users on a single connection
(used by
srv(4),
and also by Unix systems to see Plan 9 files).
tcp17007
serve a piece of the name space using the Plan 9 file system protocol,
with authentication at the start,
optional SSL encryption,
and no multiplexing of users
(typically used by
cpu(1)
and
import(4)).
Not usable by user
none.
tcp17008
like
tcp17007,
but serves the root of the tree,
forgoing the negotiation for which subtree to serve.
tcp17009
rx
remote execution.
tcp17010
server for
cpu(1)
command.
tcp17013
server for old
cpu(1)
command for compatibility with old clients.
tcp17019
server for
rcpu(1),
replaces
rx,
import(4)
and
cpu(1)
using TLS for encryption.
tcp17020
TLS encrypted 9P fileserver (t9fs) for
srvtls
(see
srv(4)).
tcp7
echo any bytes received (bit mirror)
tcp9
consume any bytes received (bit bucket)
tcp19
chargen
service.
tcp21
FTP daemon
tcp23
telnet
terminal connection.
tcp25
mail delivery.
tcp53
TCP port for DNS.
tcp110
POP3 port.
tcp113
Ident
port (always reports
none).
tcp143
IMAP4rev1 port.
tcp445
CIFS/SMB file sharing.
tcp513
rlogin
terminal connection.
tcp515
LP daemon; see
lp(8).
tcp565
report the address of the incoming call.
tcp993
Secure IMAP4rev1 port.
tcp995
Secure POP3 port.
tcp1723
PPTP (point-to-point tunnelling protocol) service.
At least the following services are available in
/bin/service.auth,
the usual
trustsrvdir.
tcp566
validate a SecureNet box.
tcp567
Plan 9 authentication-ticket service.
Listen1
is a lightweight listener intended for personal use,
modeled from Inferno’s
listen(1).
It announces on
address,
running
cmd
args...
for each incoming connection;
the network directory is passed in the environment
as
$net.
Option
-t
causes
listen1
to run as the invoking user; the default
is to become
none
before listening.
Option
-1
arms a one-shot listener; it terminates listen1
upon receiving a single call.
Option
-v
causes verbose logging on standard output.
See
/rc/bin/tlssrvtunnel
for an example.
FILES
/net/tcp
by convention, TCP device bind point
SOURCE
/sys/src/cmd/aux/listen*.c
/rc/bin/service*
SEE ALSO
authsrv(6),
dial(2)
BUGS
Srvdir,
trustsrvdir
and
namespace
must all be absolute path names.