Table of Contents
linxcfg - a configuration utility for LINX links to other nodes
linxcfg
[-t <cm>] [-v] <command> [COMMAND PARAMETERS and OPTIONS]
linxcfg [-t <cm>] [-v]
destroy <linkname>
linxcfg -h
linxcfg help <cm>
linxcfg -t <cm> [help]
linxcfg
is the LINX configuration utility. Depending on the command given, linxcfg
can destroy or create links using the specified Connection Manager (CM).
linxcfg has common options to all commands which should be placed
before the actual command
- -h
- Display help and exit.
- -t <cm>
- Specifies cm as
the Connection Manager to use. If this option is not provided, eth will
be used as the default CM.
You can use option -h to list all available CMs.
- -v
- Verbose mode.
- create PARAMETERS
- Creates a connection link to
another node. The PARAMETERS depend on the CM specified, see below for more
details.
A remote link cannot be used until also the remote node creates
the other end of the link (a link back to the originating node). The state
is "connecting" until both sides are ready and communication via the LINX
protocol can begin.
- destroy <linkname>
- Destroy the connection link with
the name linkname.
- help [<cm>]
- Provides help about the given cm , either
specified in -t or after the help command.
If no cm was specified, it will
show a list of available CMs.
The Ethernet CM is specified with the eth keyword, which is
actually the default if no other CM was specified.
The create command
takes the following options:
- create <macaddr> <interface> <linkname> [OPTIONAL
PARAMETERS]
-
- macaddr
- Specify the remote mac address of the node to connect
to, e.g. 0a:1b:2c:3d:4d:5e.
- interface
- Specify the Ethernet interface to
use. Ex.: eth0.
- linkname
- Name of the connection link. This is the link part
of the path in a remote hunt name to LINX endpoints on the other node. It
will also be the name seen in /proc/net/linx/cm/eth/<linkname>
- Optional
parameters
-
- window_size=nnn
- This is the send/receive window_size, in number
of packets on the link, and may need to be modified to adapt LINX to really
slow or really fast Ethernet performance.
Both the local and remote side negotiate the window size, being the smallest
of the two sizes the selected one. The default 128 messages should be sufficient
in most configurations. The window size shall always be of a power of 2.
Size 0 means to use the default window size.
- defer_queue_size=nnn
- The defer
queue size is in packages, with the size depending on the LINX link. The
defer queue is used on the sender side when the send queue is full. Every
message sent, when the send queue is full, is stored in the defer queue,
until the send queue has room for more messages. The defer queue size is
the maximum number of packages, with messages, that can be stored in the
defer queue before the link is disconnected, due to lack or resources.
The default value 2048 packages should be sufficient in most systems. Size
0 means to use the default defer queue size.
- send_tmo=nnn
- The send acknowledge
timeout specifies the time (in msec) to wait until unacknowledged messages
are resent. The default 10 should be sufficient in most systems. Size 0 means
to use the default timeout.
- nack_tmo=nnn
- The retransmission timeout specifies
the time (in msec) to wait until nack messages are resent. The default 20
should be sufficient in most systems. Size 0 means to use the default timeout.
- conn_tmo=nnn
- The connect timeout specifies the time (in msec) to wait
until an attempt to establish a connection is considered failed. The default
200 should be sufficient in most systems. Size 0 means to use the default
timeout.
- live_tmo=nnn
- The connection supervision timeout specifies the
time (in msec) to wait until a connection is considered broken. Default
is 100 (when the system is not idle) and should be sufficient in most systems.
When the system is idle, the live timeout is ten times larger than the
configured live timeout value. Size 0 means to use the default timeout.
- mtu=nnn
- The MTU (Maximum Transmission Unit) specifies the size in bytes
of the largets packet that the Ethernet protocol can pass onwards (this
excludes the size of the Ethernet header). If not set the MTU is fetched
from the interface. Typcially a MTU of 1500 bytes is used for Ethernet.
- coalesce=[his,los,hir,lor | off]
- NOTE: This feature is still experimental!
If this configuration is set, adaptive software-controlled Ethernet coalescing
is enabled. The default is off. The high send/receive thresholds his and
hir specify the number of sent/received messages/200msec that need to be
sent/received to enable coalescing in the specific direction. The low send/receive
thresholds los and lor specify when to disable coalescing in the specific
direction. Adaptive coalesting means to dynamically optimize the throughput
by collecting multiple small messages in each package, but still avoiding
delays due to long time periods between messages. The coalesce configuration
may require device specific tuning, e.g. by running a benchmark with different
coalesce configurations.
- attributes=s
- The attribute option gives the possibility
to assign an arbitrary string to the link when it is created. This string
is included in the new_link signal, which is sent to all link supervisors.
More information on link supervisors can be found in linx(7)
man page.
The TCP CM is specified using the tcp keyword.
The create command
takes the following parameters:
create <ip> <linkname> [OPTIONAL PARAMETERS]
- ip
- The IP address to connect to.
- linkname
- Name of the connection link.
This is the LINX link part of the path in a remote hunt name to LINX endpoints
on the other node. It will also be the name seen in /proc/net/linx/cm/tcp/<linkname>
- Optional parameters
-
- live_tmo=<size>
- The live_tmo parameter is the time in
milliseconds between every heartbeat that is used to detect if the connection
has gone down. The default value is 250 ms.
- use_nagle=<bool>
- Set to 1 if nagle
algorithm shall be used on the socket for the connection. Default is off.
- attributes=<s>
- The attribute option gives the possibility to assign an arbitrary
string to the link when it is created. This string is included in the new_link
signal, which is sent to all link supervisors.
None.
linxcfg
will display more verbose information to standard out, if the -v option
is specified.
None.
linxcfg create 01:23:a4:4f:b3:ac eth0
conn_A
linxcfg destroy conn_A
linxcfg -t tcp create 192.168.1.1 conn_A
linxcfg
-
t tcp destroy conn_A
linx(7)
, linxstat(1)
, linxdisc(8)
Enea
LINX team
Copyright (c) 2006-2007, Enea Software AB All rights
reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are
met:
Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer. Redistributions in
binary form must reproduce the above copyright notice, this list of conditions
and the following disclaimer in the documentation and/or other materials
provided with the distribution. Neither the name of Enea Software AB nor
the names of its contributors may be used to endorse or promote products
derived from this software without specific prior written permission.
THIS
SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Table of Contents