Shorewall and Linux-vserver
Tom
Eastep
2010
Thomas M. Eastep
Permission is granted to copy, distribute and/or modify this
document under the terms of the GNU Free Documentation License, Version
1.2 or any later version published by the Free Software Foundation; with
no Invariant Sections, with no Front-Cover, and with no Back-Cover
Texts. A copy of the license is included in the section entitled
GNU Free Documentation
License
.
Introduction
Formal support for Linux-vserver was added in Shorewall 4.4.11
Beta2. The centerpiece of that support is the
vserver zone type. Vserver zones have the following
characteristics:
They are defined on the Linux-vserver host.
The $FW zone is their implicit parent.
Their contents must be defined using the shorewall-hosts (5)
file.
They may not appear in the ZONE column of the shorewall-interfaces
(5) file.
If you use these zones, keep in mind that Linux-vserver implements a
very weak form of network virtualization:
From a networking point of view, vservers live on the host
system. So if you don't use care, Vserver traffic to/from zone z will
be controlled by the fw->z and z->fw rules and policies rather
than by vserver->z and z->vserver rules and policies.
Outgoing connections from a vserver will not use the Vserver's
address as the SOURCE IP address unless you configure applications
running in the Vserver properly. This is especially true for IPv6
applications. Such connections will appear to come from the $FW zone
rather than the intended Vserver zone.
Vserver Zones
You create a zone that includes one or more Linux-vserver instances
as follow.
/etc/shorewall/zones:
#ZONE TYPE OPTIONS ...
fw firewall
loc ip #Local Zone
drct:loc ipv4 #Direct internet access
net ipv4 #Internet
vpn ipv4 #OpenVPN clients
dmz vserver #Vservers
/etc/shorewall/hosts:
#ZONE HOST(S) OPTIONS
drct eth3:dynamic
dmz eth1:70.90.191.124/31
While the IP addresses 70.90.191.124 and 70.90.191.125 are
configured on eth1, the actual interface name is irrelevate so long as the
interface is defined in shorewall-interfaces (5).
Shorewall will consider all vserver zones to be associated with the
loopback interface (lo).
Once a vserver zone is defined, it can be used like any other zone
type.