mirror of
git://slackware.nl/current.git
synced 2024-12-31 10:28:29 +01:00
555 lines
28 KiB
Text
555 lines
28 KiB
Text
|
Slackware Network Configuration
|
||
|
===============================
|
||
|
|
||
|
Networking in Slackware is configured by the /etc/rc.d/rc.inet1 script, and the
|
||
|
configuration file /etc/rc.d/rc.inet1.conf. Wireless interfaces are configured
|
||
|
just like any network interface, but accept many more configuration parameters.
|
||
|
|
||
|
The rc.inet1.conf file contains a series of variable array definitions, with
|
||
|
each array index corresponding to a single network interface. This means that
|
||
|
each set of parameters with an index of 0 configure the first interface (since
|
||
|
indexing starts at 0), parameters with an index of 1 configure the second
|
||
|
interface, and so on. Not all parameters need to be set for each type of
|
||
|
interface, or interface number. This is better illustrated with examples,
|
||
|
which you will find in the documentation below.
|
||
|
|
||
|
|
||
|
Starting and Stopping Interfaces
|
||
|
--------------------------------
|
||
|
The way to start networking (configuring all NICs, bringing the interfaces up,
|
||
|
and creating a default route, if required) is by running the command:
|
||
|
/etc/rc.d/rc.inet1 start
|
||
|
This command will configure all networking interfaces which are defined in the
|
||
|
configuration file, and is used at boot time to bring networking up.
|
||
|
|
||
|
The counterpart to this is the:
|
||
|
/etc/rc.d/rc.inet1 stop
|
||
|
command, which will bring all networking to a stop. It is advised to use this
|
||
|
with caution as it can make your host completely inaccessable from the network.
|
||
|
|
||
|
Restarting the whole network (all available network interfaces) and resetting
|
||
|
the default gateway (if set) is done in a similar fashion to starting it:
|
||
|
/etc/rc.d/rc.inet1 restart
|
||
|
And will first deconfigure all interfaces, before bringing them back up - which
|
||
|
is functionally equalivant to a 'stop' and 'start' operation.
|
||
|
|
||
|
More specifically speaking, you can start/stop/restart any network interface on
|
||
|
an individual basis using the commands:
|
||
|
/etc/rc.d/rc.inet1 <interface>_start
|
||
|
/etc/rc.d/rc.inet1 <interface>_stop
|
||
|
/etc/rc.d/rc.inet1 <interface>_restart
|
||
|
where <interface> is the name of an existing network interface (eth0, eth1,
|
||
|
wlan0, etc).
|
||
|
|
||
|
|
||
|
Guided Networking Configuration
|
||
|
-------------------------------
|
||
|
The 'netconfig' script is capable of configuring basic networking parameters for
|
||
|
the first ethernet interface of the system, and writing an annotated
|
||
|
/etc/rc.d/rc.inet1.conf configuration file. 'netconfig' is usually invoked
|
||
|
during installation to configure the first ethernet interface of your freshly
|
||
|
installed system.
|
||
|
|
||
|
'netconfig' is capable of configuring a set of IPv4 and/or IPv6 addresses for an
|
||
|
interface, or setting the interface to be configured using DHCP (both DHCPv4 and
|
||
|
DHCPv6) and IPv6 StateLess Address Auto Configuration (SLAAC). The default
|
||
|
gateways and nameservers can also be configured through the guided interface.
|
||
|
|
||
|
The option to use NetworkManager for interface configuration (instead of
|
||
|
rc.inet1.conf) is also available.
|
||
|
|
||
|
For most users with a single ethernet interface, and simple IP configuration
|
||
|
requirements, 'netconfig' can completely configure the networking sub-system for
|
||
|
you.
|
||
|
|
||
|
|
||
|
Deprecated and New IPv4 Configuration Syntax
|
||
|
--------------------------------------------
|
||
|
With the release of Slackware 15.0, several parameters used in older
|
||
|
rc.inet1.conf configurations have become deprecated and are substituted by a
|
||
|
new, singular, IP parameter for v4 addresses.
|
||
|
|
||
|
Specifically, the following parameters used in previous rc.inet1.conf
|
||
|
configurations to configure IPv4 addresses have become deprecated:
|
||
|
IPADDR[x]=""
|
||
|
NETMASK[x]=""
|
||
|
IPALIASES[x]=""
|
||
|
These parameters should no longer be used in new configurations.
|
||
|
|
||
|
New configurations should use the updated syntax parameter:
|
||
|
IPADDRS[x]=""
|
||
|
which can hold multiple, space delimited, IPv4 addresses with their CIDR
|
||
|
masks in order to configure an interface.
|
||
|
|
||
|
The format for the addresses specified in this new parameter is:
|
||
|
IP-address/mask
|
||
|
For example:
|
||
|
IPADDRS[0]="192.168.0.1/24 10.10.10.10/8"
|
||
|
which would be the equilivant of old syntax:
|
||
|
IPADDR[0]="192.168.0.1"
|
||
|
NETMASK[0]="255.255.255.0"
|
||
|
IPALIASES[0]="10.10.10.10/8"
|
||
|
|
||
|
If a mask (in CIDR notation) is not provided with the IP address in IPADDRS, it
|
||
|
is assumed to be /24 (aka, 255.255.255.0). A warning will also be emitted about
|
||
|
the missing mask.
|
||
|
|
||
|
rc.inet1 is fully backwards compatible with the older syntax - old configuration
|
||
|
files will contiinue to be accepted for the foreseeable future, but 'netconfig'
|
||
|
has been adjusted to output the new syntax.
|
||
|
|
||
|
Notes:
|
||
|
* When DHCP or SLAAC is used to dynamically configure the interface, IP
|
||
|
addresses specified in IPADDRS will be added to the interface as alias IPs.
|
||
|
However, any address specified in IPADDR is *not* added to the interface in
|
||
|
order to maintain backwards semantics with the pre 15.0 rc.inet1.
|
||
|
* Should an rc.inet1.conf contain both the IPADDR and IPADDRS parameters
|
||
|
(without DHCP or SLAAC being in use) the addresses listed in IPADDRS will be
|
||
|
added to the interface after the IPADDR address is set.
|
||
|
|
||
|
|
||
|
Manual Networking Configuration
|
||
|
-------------------------------
|
||
|
FIXME
|
||
|
|
||
|
|
||
|
IPv6
|
||
|
----
|
||
|
Overview
|
||
|
~~~~~~~~
|
||
|
|
||
|
With the new IPv4 syntax detailed above, there is the addition of optional
|
||
|
configuration semantics for IPv6.
|
||
|
|
||
|
The IPv6 capabilities in Slackware 15.0+ are as follows:
|
||
|
* Dual stack. Interfaces can be configured with an IPv4 address or an IPv6
|
||
|
address, or both.
|
||
|
* Each interface can have single or multiple v4 and/or v6 IPs.
|
||
|
* Optional StateLess Address Auto Configuration (SLAAC) of v6 IP addresses,
|
||
|
for quick and easy IPv6 configuration on supported networks.
|
||
|
* DHCPv6 support for server controlled dynamic address configuration.
|
||
|
* Fixed IPv6 addresses configured interfaces.
|
||
|
|
||
|
'netconfig' can be used for guided configuration of all of the above features,
|
||
|
or they can be configured manually using the options below.
|
||
|
|
||
|
|
||
|
IPv6 Parameters
|
||
|
~~~~~~~~~~~~~~~
|
||
|
v6 IPs can be configured via SLAAC, DHCP6 or statically using the following
|
||
|
new options for rc.inet1.conf:
|
||
|
USE_SLAAC[x]="" Allow StateLess Address Auto Configuration of a
|
||
|
(potentially) globally routable v6 IP. With this
|
||
|
parameter set to "yes", the interface's v6 IP will ONLY
|
||
|
be configured via SLAAC, even if Router Advertisment
|
||
|
indicates DHCPv6 is available on the network - if SLAAC
|
||
|
is not available on the network, no IPv6 address will be
|
||
|
assigned.
|
||
|
|
||
|
Since 'dhcpcd' is capable of handling SLAAC as well as
|
||
|
DHCPv6, it is better practice to set USE_DHCP6[x]="yes"
|
||
|
to perform full auto configuration instead.
|
||
|
|
||
|
USE_DHCP6[x]="" Use 'dhcpcd' to configure the interface. This will
|
||
|
bring up the interface using DHCPv6, falling back to
|
||
|
SLAAC (if supported on the network), or will leave the
|
||
|
interface unconfigured after a timeout. When this
|
||
|
parameter is set to "yes", the USE_SLAAC[x] option is
|
||
|
ignored.
|
||
|
|
||
|
This is the preferred option to configure an interface
|
||
|
dynamically - whether the network is setup for DHCPv6 or
|
||
|
SLAAC, 'dhcpcd' will be able to configure the interface.
|
||
|
|
||
|
IP6ADDRS[x]="" The static v6 IP addresses for the interface. This
|
||
|
parameter takes a list of v6 IP addresses and prefix
|
||
|
lengths in CIDR notation, in a space delimited list.
|
||
|
For example: IP6ADDRS[x]="a:b:c:d:e::1/48 1:2:3:4::5/64"
|
||
|
|
||
|
If a prefix length is not given (separated from the IP
|
||
|
address with a /), a length of 64 will be assumed, and
|
||
|
a warning emitted about the unset value.
|
||
|
|
||
|
When either the USE_DHCP6[x] or USE_SLAAC[x] options are
|
||
|
set to "yes", the IP addresses listed in this parameter
|
||
|
are also added to the interface, but only upon sucessful
|
||
|
assigning of the dynamic IP address.
|
||
|
|
||
|
A static gateway can be configured using this parameter:
|
||
|
GATEWAY6="" The default IPv6 gateway for the network. This is a
|
||
|
single IPv6 address in standard format, without a
|
||
|
prefix suffix.
|
||
|
|
||
|
The following lesser used misc options can be used for tailouring of the IPv6
|
||
|
configuration process:
|
||
|
USE_RA[x]="" Normally, unless USE_SLAAC[x]="yes" is set, Router
|
||
|
Advertisment (RA) is disabled for the interface as it
|
||
|
can result in extraneous routes being added to the
|
||
|
routing table. With this option set to "yes", RA
|
||
|
packets will be accepted on the interface even when DHCP
|
||
|
or fixed IP addressing is used, and the routes
|
||
|
advertised by the router will be added to the table.
|
||
|
|
||
|
Conversely, if this parameter is explicitly set to "no",
|
||
|
RA will be disabled at all times - meaning SLAAC cannot
|
||
|
be performed even when USE_SLAAC[x]="yes" is set. The
|
||
|
default (unset) is to enable RA when SLAAC is in use,
|
||
|
and to disable it otherwise.
|
||
|
|
||
|
The use of this parameter should rarely be required as
|
||
|
rc.inet1 will do the right thing.
|
||
|
|
||
|
SLAAC_TIMEOUT[x]="" The time to wait (in seconds) for an interface to be
|
||
|
configured by SLAAC. When unset, the default is 15.
|
||
|
Some networks may require a longer period for the router
|
||
|
to broadcast an advertisement packet on the network, so
|
||
|
may need to increase this value.
|
||
|
|
||
|
|
||
|
Disabling IPv6
|
||
|
~~~~~~~~~~~~~~
|
||
|
For some use cases, where IPv6 support is not required at all, disabling IPv6
|
||
|
may be a better option than leaving the interface unconfigured.
|
||
|
|
||
|
There are two similar methods which can be used to disable IPv6. Both of the
|
||
|
options involve creating (or replacing the content if it already exists in)
|
||
|
the file:
|
||
|
/etc/modprobe.d/ipv6.conf
|
||
|
(which overrides any configuration in the /lib/modprobe.d/ipv6.conf file),
|
||
|
with the content:
|
||
|
alias ipv6 off
|
||
|
alias net-pf-10 off
|
||
|
Or:
|
||
|
install ipv6 /bin/true
|
||
|
install net-pf-10 /bin/true
|
||
|
|
||
|
It is important to disable both the 'ipv6' and 'net-pf-10' modules since the
|
||
|
module can be automatically loaded by either name.
|
||
|
|
||
|
|
||
|
Changes From Previous Behaviour
|
||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||
|
* Previous to Slackware 15.0, if the network the host is connecting to is set
|
||
|
up for StateLess Address Auto Configuration (SLAAC), the host would bring up
|
||
|
an interface with a (potentially) globally routable IPv6 address with no
|
||
|
configuration by the user. This has been changed so that all network
|
||
|
configuration must be explicitly enabled. Thus, interfaces will no longer
|
||
|
automatically come up with a valid IPv6 address on networks which support
|
||
|
auto configuration, without enabling the USE_SLAAC[x]="yes" parameter for
|
||
|
the interface. This is a security enhancement.
|
||
|
|
||
|
* Unless RA is explicitly enabled using the USE_RA[x]="yes" option, rc.inet1
|
||
|
now disables RA (via the accept_ra tunable in /proc) for an interface before
|
||
|
trying to add any IPs configured for it. This prevents RA on the network
|
||
|
from automatically adding any routes to the table. When USE_SLAAC[x]="yes"
|
||
|
is set, RA is implicitly re-enabled for the interface (since SLAAC and RA
|
||
|
are usually used together on a network), unless explicitly disabled with
|
||
|
USE_RA[x]="no". This is a change from previous versions of Slackware, which
|
||
|
would auto configure routes without any user intevention. This is a
|
||
|
security enhancement.
|
||
|
|
||
|
|
||
|
Caveats
|
||
|
~~~~~~~
|
||
|
* When being configured with the USE_DHCP[x]="yes" and USE_DHCP6[x]="yes"
|
||
|
parameters for an interface (that is, configured to obtain both a v4 and v6
|
||
|
addresses via DHCP), 'dhcpcd' will only wait until one type of IP is
|
||
|
obtained before backgrounding - it will not wait for both a v4 AND v6 to be
|
||
|
configured. This means there is no way to know if the interface has been
|
||
|
completely configured for both types of IP, as one type will continue to be
|
||
|
sought in the background; but MAY ultimately fail. This is an issue with
|
||
|
the way dhcpcd operates, not an issue with rc.inet1.
|
||
|
|
||
|
|
||
|
Bonding / Link Aggregation
|
||
|
--------------------------
|
||
|
Overview
|
||
|
~~~~~~~~
|
||
|
Bonding (or Link Aggregation) is a teccnique for combining two or more
|
||
|
physical interfaces into a single, logical, interface; a logical interface
|
||
|
which has all the capabilities of a single physical interface.
|
||
|
|
||
|
The Slackware bonding options provide full support for the features offered by
|
||
|
the bonding kernel module, in the familiar Slackware parameter configuration
|
||
|
syntax. Included is the ability to select the bonding mode, easy addition of
|
||
|
interfaces to a bond using a new parameter in rc.inet1.conf, and the setting
|
||
|
of bonding module options via a new, generic, IFOPTS[x] parameter.
|
||
|
|
||
|
At this time 'netconfig' is unable to configure bonded interfaces, so they
|
||
|
must be configured manually with the parameters detailed below.
|
||
|
|
||
|
|
||
|
Bonding Parameters
|
||
|
~~~~~~~~~~~~~~~~~~
|
||
|
Bonded interfaces can be configured via two new bond specific parameters for
|
||
|
use in rc.inet1.conf, plus the new, generic, IFOPTS[x] parameter. The new
|
||
|
bonding parameters are:
|
||
|
BONDNICS[x]="" The space delimited list of interfaces to add to this
|
||
|
bond. The interfaces will be brought up and configured
|
||
|
while bringing up the interface, so do not need to be
|
||
|
previously defined in rc.inet1.conf. A bond can be
|
||
|
created with only 1 interface, but does not become
|
||
|
useful until at least 2 interfaces are configured.
|
||
|
|
||
|
BONDMODE[x]="" This parameter sets the bonding mode for the logical
|
||
|
interface. If not specified when BONDNICS[x] has been
|
||
|
used, the default is 'balance-rr'. See below for a
|
||
|
list of all bonding modes available.
|
||
|
|
||
|
|
||
|
Bonding Modes
|
||
|
~~~~~~~~~~~~~
|
||
|
When a bonded logical interface is created, it needs to operate in a
|
||
|
particular mode. By default that mode is 'balance-rr'. The following modes,
|
||
|
along with details of their functionallity, are available using the kernel
|
||
|
bonding driver:
|
||
|
802.3ad Also known as LACP. This mode requires a switch that
|
||
|
supports an IEEE 802.3ad. The physical interfaces must
|
||
|
share the same speed and duplex settings and form a
|
||
|
logical interface which provides fault tolerance and
|
||
|
load balancing.
|
||
|
active-backup When in this mode only one interface set to active,
|
||
|
while all other interfaces are in the backup state. If
|
||
|
the active interface fails, a backup interface replaces
|
||
|
it as the only active interface in the bond. This mode
|
||
|
only provides fault tolerance, no load balancing.
|
||
|
This mode requires that the 'primary <interface>'
|
||
|
option be configured with the IFOPTS[x]="" parameter.
|
||
|
balance-alb The receiving packets are load balanced through Address
|
||
|
Resolution Protocol (ARP) negotiation. This mode
|
||
|
provides fault tolerance and load balancing.
|
||
|
balance-rr This mode is also known as round-robin mode. Packets
|
||
|
are sequentially transmitted and received through each
|
||
|
interface one by one. This mode provides load
|
||
|
balancing functionality along with fault tolerance.
|
||
|
This is the default mode of operation.
|
||
|
balance-tlb This mode ensures that outgoing traffic is distributed
|
||
|
according to the load on each physical interface. If
|
||
|
one interface fails to receive traffic, another
|
||
|
interface is assigned to the receiving role. This mode
|
||
|
provides fault tolerance and load balancing.
|
||
|
balance-xor The source MAC address uses eXclusive OR (XOR) logic
|
||
|
with the destination MAC address in order to determine
|
||
|
which physical interface the packet should be sent via.
|
||
|
This calculation ensures that the same physical (slave)
|
||
|
interface is selected for each destination host. If the
|
||
|
physical interface to be used is in a failed state, one
|
||
|
of the backup interfaces is used instead. This mode
|
||
|
provides fault tolerance and load balancing.
|
||
|
broadcast All packets are sent to all the physical (slaved)
|
||
|
interfaces at once. This mode provides fault tolerence
|
||
|
but may result in duplicate packets arriving at the
|
||
|
destination host, assuming they are not screened out by
|
||
|
networking hardware.
|
||
|
|
||
|
|
||
|
Bonding Options
|
||
|
~~~~~~~~~~~~~~~
|
||
|
Bonding specific options can be set using the the IFOPTS[x]="" paramter (which
|
||
|
takes a pipe (|) delimited list of options) for the interface being
|
||
|
configured. The following are the most useful options (but not an exhaustive
|
||
|
list - see "Further Reading" below for more information) which can be set:
|
||
|
lacp_rate This option specifies the rate at which the host will
|
||
|
ask the switch to transmit LACPDU packets in 802.3ad
|
||
|
mode. Possible values are:
|
||
|
slow Transmit LACPDUs every 30 seconds.
|
||
|
fast Transmit LACPDUs every 1 second.
|
||
|
The default is slow, but fast is recommended for rapid
|
||
|
recovery after a physical link failure.
|
||
|
miimon Specifies the MII link monitoring frequency in
|
||
|
milliseconds. This determines how often the link state
|
||
|
of each physical (slaved) interface is checked for link
|
||
|
failures. A value of zero disables MII link monitoring,
|
||
|
but this is NOT advised. A value of 100 is a good
|
||
|
starting point. The default value is 0, so be sure to
|
||
|
set this option with ALL bonding modes.
|
||
|
primary The physical (slave) interface (eth0, eth1, etc) which
|
||
|
is to be used as the primary interface. The specified
|
||
|
interface will always be the active slave while it is
|
||
|
available. Only when the primary interface is off-line
|
||
|
will alternate interfaces be used. This is useful when
|
||
|
one interface is preferred over another (e.g. when one
|
||
|
interface has higher throughput than another). This
|
||
|
option is only valid for "active-backup", "balance-tlb",
|
||
|
and "balance-alb" bonding modes.
|
||
|
xmit_hash_policy Selects the transmit hash policy to use for interface
|
||
|
selection in "balance-xor", "802.3ad", and "balance-tlb"
|
||
|
bonding modes. Possible values are:
|
||
|
layer2 Use eXclusive OR (XOR) of source and
|
||
|
destination MAC addresses and packet
|
||
|
type ID fields to generate the hash.
|
||
|
This algorithm will place all traffic
|
||
|
to a particular destination on the
|
||
|
same phydivsl (slave) interface.
|
||
|
layer2+3 Use a combination of layer2 and
|
||
|
layer3 protocol information (MAC
|
||
|
addresses and IP addresses) to
|
||
|
generate the hash. This algorithm
|
||
|
will place all traffic to a particular
|
||
|
destination on the same physical
|
||
|
(slave) interface. This policy is
|
||
|
intended to provide a more balanced
|
||
|
distribution of traffic than layer2
|
||
|
alone.
|
||
|
layer3+4 This policy uses upper layer protocol
|
||
|
information, when available, to
|
||
|
generate the hash. This allows for
|
||
|
traffic to a particular destination to
|
||
|
span multiple physical (slave)
|
||
|
interfaces, although a single
|
||
|
connection will not span multiple
|
||
|
slaves.
|
||
|
The default value is layer2. Additional (lesser used)
|
||
|
policies are available - see the "Further Reading"
|
||
|
section below for further details.
|
||
|
|
||
|
|
||
|
Caveats
|
||
|
~~~~~~~
|
||
|
* The IFOPTS[x]="" parameter should always include the 'miimon' option - not
|
||
|
using this option will result in network degradation.
|
||
|
* In "active-backup" mode, the "primary" option should also always be
|
||
|
supplied.
|
||
|
* When using "802.3ad" mode, set "lacp_rate fast" for faster recovery from an
|
||
|
interface failure. In other modes, the 'xmit_hash_policy' should be set.
|
||
|
|
||
|
|
||
|
Examples
|
||
|
~~~~~~~~
|
||
|
FIXME: Add examples.
|
||
|
|
||
|
|
||
|
Further Reading
|
||
|
~~~~~~~~~~~~~~~
|
||
|
Full documentation of the bonding layer is available in the kernel source
|
||
|
documentation at: /usr/src/linux/Documentation/networking/bonding.txt.
|
||
|
|
||
|
|
||
|
VLANs (a.k.a, 802.1q)
|
||
|
---------------------
|
||
|
Overview
|
||
|
~~~~~~~~
|
||
|
Virtual LANs (VLANs) allow the segmentation of physical networks into
|
||
|
multiple, isolated, private virtual networks, whilst using shared network
|
||
|
switches and hardware.
|
||
|
|
||
|
VLANs work by applying tags to network frames to form virtual private LANs.
|
||
|
In this way, VLANs can keep network applications separate despite being
|
||
|
connected to the same physical network, and without requiring multiple sets of
|
||
|
cabling and networking devices to be deployed.
|
||
|
|
||
|
In essence, a VLAN is a collection of devices or network hosts that
|
||
|
communicate with one another as if they make up a single LAN, but utilising
|
||
|
shared network hardware.
|
||
|
|
||
|
Because VLAN frames are tagged with a VLAN ID, it is possible to 'cherry-pick'
|
||
|
those frames from the network by use of a VLAN interface on the host.
|
||
|
|
||
|
Slackware now allows configuration of such interfaces in order to allow a host
|
||
|
to join a specific VLAN or VLANs. The guided deployment in 'netconfig' has
|
||
|
been updated to support the creation of such VLAN interfaces.
|
||
|
|
||
|
The configuration in rc.inet1.conf for VLANs is a simple modification of the
|
||
|
existing support for declaration of a network interface using the standard
|
||
|
Slackware IFNAME[x] parameter. As shown in the examples below, VLANs
|
||
|
interfaces can be built on top on top of regular, physical, interfaces, or on
|
||
|
top of a bond interface to allow for link aggregation.
|
||
|
|
||
|
The new IFOPT[x] generic interface options parameter can be used to customise
|
||
|
the usage and configuration of the VLAN interfaces, but is not required in a
|
||
|
normal configuration setting.
|
||
|
|
||
|
|
||
|
Exposing VLANs
|
||
|
~~~~~~~~~~~~~~
|
||
|
Configuring VLAN interfaces utilises the standard Slackware networking
|
||
|
configuration syntax in rc.inet1.conf; with setting up an interface as simple
|
||
|
as changing the IFNAME[x]="" parameter.
|
||
|
|
||
|
VLAN interfaces can be configured quite simply in rc.inet1.conf, in the
|
||
|
standard Slackware way of defining an interface. The key to the configuration
|
||
|
is to use the correct IFNAME[x]="" parameter for the underlying physical (or
|
||
|
bond) interface and the tagged VLAN ID that should be exposed. For example:
|
||
|
IFNAME[0]="eth0.10"
|
||
|
IFOPTS[0]=""
|
||
|
IPADDRS[0]="192.168.10.1/24"
|
||
|
|
||
|
The VLAN ID is taken from the full interface name, as set in the IFNAME[x]
|
||
|
parameter which is comprised of the underlying physical (or bond) interface
|
||
|
name, a period (.) and the VLAN ID to expose. The above example would use the
|
||
|
physical interface 'eth0', and expose the VLAN with ID 10, and configure the
|
||
|
interface with the IPv4 address 192.168.10.1 with a mask of 24.
|
||
|
|
||
|
IFOPTS[x]="" is a pipe (|) delimited list of VLAN kernel module specific
|
||
|
settings to be applied to the interface. The ip-link(8) man page contains
|
||
|
details of exactly what settings can be used with this option (search for
|
||
|
"VLAN Type Support"). For example:
|
||
|
IFOPTS[x]="protocol 802.1ad | reorder_hdr off"
|
||
|
Under normal circumstances, where a standard VLAN interface is required, no
|
||
|
options need be supplied.
|
||
|
|
||
|
|
||
|
Examples
|
||
|
~~~~~~~~
|
||
|
FIXME: Add examples.
|
||
|
|
||
|
|
||
|
Bridges
|
||
|
-------
|
||
|
|
||
|
|
||
|
Wireless (WiFi) Network Interfaces
|
||
|
----------------------------------
|
||
|
|
||
|
|
||
|
TUN/TAP
|
||
|
-------
|
||
|
|
||
|
|
||
|
Advanced networking configuration
|
||
|
---------------------------------
|
||
|
(stacking interface configs - bond, then VLAN, then bridge)
|
||
|
|
||
|
It is also possible to use a bond as the underlying interface, which allows
|
||
|
link aggregated VLAN interfaces to be created for network redundancy. For
|
||
|
example:
|
||
|
IFNAME[0]="bond0"
|
||
|
BONDNICS[0]="eth0 eth1"
|
||
|
BONDMODE[0]="active-backup"
|
||
|
IFOPTS[0]="miimon 100 | primary eth0"
|
||
|
IFNAME[1]="bond0.5"
|
||
|
IFNAME[2]="br0"
|
||
|
BRNICS[2]="bond0.5"
|
||
|
IPADDRS[2]="192.168.5.10/24"
|
||
|
IP6ADDRS[2]="a:b:c:d::1/64"
|
||
|
Would create a bond interface using the eth0 and eth1 physical ethernet
|
||
|
interfaces, in an "active-backup" redundancy configuration with the primary
|
||
|
interface being "eth0", exposing VLAN ID 5 and setting an IPv4 address of
|
||
|
"192.168.5.10" mask "24", plus an IPv6 address of "a:b:c:d::1" prefix "64"
|
||
|
for the interface.
|
||
|
|
||
|
|
||
|
General Caveats
|
||
|
---------------
|
||
|
|
||
|
The network interface definitions are stored in variable arrays. The bash shell has no facilities to retrieve the largest array index used. There-
|
||
|
fore, the rc.inet1 script makes the assumption that array indexes stay below the value of 6. Effectively this means that you can configure up to 6
|
||
|
network interfaces in rc.inet1.conf by default.
|
||
|
|
||
|
If you want to configure more than six network interfaces, you will have to edit the file /etc/rc.d/rc.inet1.conf and change the value `6' in the
|
||
|
line:
|
||
|
#MAXNICS="6"
|
||
|
(at the very bottom of the file) to a value that is larger than the largest index value you use, and uncomment the line.
|
||
|
|
||
|
The /etc/rc.d/rc.wireless script is not meant to be run on its own by the user!
|
||
|
|
||
|
|
||
|
rc.inet1 does not keep a record of how an interface was configured. If the
|
||
|
interface config is changed in rc.inet1.conf from, say, DHCP to static IP,
|
||
|
restarting networking may fail because the previous type of interface config
|
||
|
cannot be stopped (because its type is unknown). In this instance, it is easier
|
||
|
to reboot to start from fresh. However, if reboot is not possible, it may be
|
||
|
required to bring the interface down manually (either by deconfiguring the IPs,
|
||
|
or killing dhcpcd) before trying to restart the interface.
|
||
|
|