2011-03-30 13:49:47 +00:00
|
|
|
.TH AAN 8
|
|
|
|
.SH NAME
|
2014-04-14 23:05:57 +00:00
|
|
|
aan, aanuke \- always available network
|
2011-03-30 13:49:47 +00:00
|
|
|
.SH SYNOPSIS
|
|
|
|
.B aan
|
|
|
|
.B -c
|
|
|
|
[
|
|
|
|
.B -d
|
|
|
|
]
|
|
|
|
[
|
|
|
|
.B -m maxto
|
|
|
|
]
|
|
|
|
.I dialstring
|
|
|
|
.br
|
|
|
|
.B aan
|
|
|
|
[
|
|
|
|
.B -d
|
|
|
|
]
|
|
|
|
[
|
|
|
|
.B -m maxto
|
|
|
|
]
|
2014-04-14 23:05:57 +00:00
|
|
|
.B aanuke
|
2011-03-30 13:49:47 +00:00
|
|
|
.I netdir
|
|
|
|
.SH DESCRIPTION
|
|
|
|
.I Aan
|
|
|
|
tunnels traffic between a client and a server through a persistent
|
|
|
|
network connection. If the connection breaks (voluntarily or
|
|
|
|
due to networking problems), the
|
|
|
|
.I aan
|
|
|
|
client re-establishes the connection by redialing the server.
|
|
|
|
.PP
|
|
|
|
.I Aan
|
|
|
|
uses a unique protocol to make sure no data is ever lost even
|
|
|
|
when the connection breaks.
|
|
|
|
After a reconnection,
|
|
|
|
.I aan
|
|
|
|
retransmits all unacknowledged data between client and server.
|
|
|
|
.PP
|
|
|
|
A connection can be broken voluntarily (e.g. by roaming over IP networks),
|
|
|
|
or a connection can break when the IP service is unreliable.
|
|
|
|
In either case,
|
|
|
|
.I aan
|
|
|
|
re-establishes the client's connection automatically.
|
|
|
|
.PP
|
|
|
|
When the server part has not heard from the client in
|
|
|
|
.I maxto
|
|
|
|
seconds, the server part of
|
|
|
|
.I aan
|
|
|
|
exits.
|
|
|
|
The default
|
|
|
|
.I maxto
|
|
|
|
is one day.
|
|
|
|
The client side (option
|
|
|
|
.BR -c )
|
|
|
|
calls the server by its
|
|
|
|
.IR dialstring ,
|
|
|
|
while the server side listens for connections in the
|
|
|
|
already-announced network directory
|
|
|
|
.IR netdir .
|
|
|
|
.PP
|
|
|
|
.I Aan
|
|
|
|
is usually run automatically through the
|
|
|
|
.B -p
|
|
|
|
option of
|
2012-12-30 17:47:32 +00:00
|
|
|
.IR import (4)
|
|
|
|
and
|
|
|
|
.IR cpu (1).
|
2014-04-14 23:05:57 +00:00
|
|
|
.PP
|
|
|
|
.I Aanuke
|
|
|
|
prints commands that will cause all processes called
|
|
|
|
.I aan
|
|
|
|
that are owned by the current user and do not have an
|
|
|
|
active tcp connection to be terminated.
|
|
|
|
Use the
|
|
|
|
.B send
|
|
|
|
command of
|
|
|
|
.IR rio (1),
|
|
|
|
or pipe the output of
|
|
|
|
.I kill
|
|
|
|
into
|
|
|
|
.IR rc (1)
|
|
|
|
to execute the commands.
|
|
|
|
.SH EXAMPLES
|
2011-03-30 13:49:47 +00:00
|
|
|
Assume the server part of
|
|
|
|
.I aan
|
|
|
|
is encapsulated in
|
|
|
|
.I exportfs
|
|
|
|
on the machine
|
|
|
|
.B sob
|
|
|
|
and started through
|
|
|
|
.B aux/listen
|
|
|
|
as follows:
|
|
|
|
.IP
|
|
|
|
.EX
|
|
|
|
netdir=`{echo $3 | sed 's;/[0-9]+$;!*!0;'}
|
|
|
|
exec exportfs -a -A $netdir
|
|
|
|
.EE
|
|
|
|
.PP
|
|
|
|
Then machine
|
|
|
|
.BR astro6 's
|
|
|
|
name space can be imported through
|
|
|
|
.I aan
|
|
|
|
using this command:
|
|
|
|
.IP
|
|
|
|
.EX
|
|
|
|
import -p astro6 / /mnt/term
|
|
|
|
.EE
|
2014-04-14 23:05:57 +00:00
|
|
|
.PP
|
|
|
|
Kill idle instances of
|
|
|
|
.I aan
|
|
|
|
left behind by a terminal that has been powered off:
|
|
|
|
.IP
|
|
|
|
.EX
|
|
|
|
aanuke | rc
|
|
|
|
.EE
|
2011-03-30 13:49:47 +00:00
|
|
|
.SH FILES
|
|
|
|
.TF /sys/log/aan
|
|
|
|
.TP
|
|
|
|
.B /sys/log/aan
|
|
|
|
Log file
|
|
|
|
.SH SOURCE
|
|
|
|
.B /sys/src/cmd/aan.c
|
2014-04-14 23:05:57 +00:00
|
|
|
.br
|
|
|
|
.B /rc/bin/aanuke
|
2011-03-30 13:49:47 +00:00
|
|
|
.SH SEE ALSO
|
|
|
|
.IR import (4),
|
2012-12-30 17:47:32 +00:00
|
|
|
.IR exportfs (4),
|
|
|
|
.IR cpu (1)
|
2014-04-14 23:09:33 +00:00
|
|
|
.SH HISTORY
|
|
|
|
.I Aanuke
|
|
|
|
first appeared in 9front (April, 2014).
|