shorewall6-providers (5) Linux Manual Page
providers – Shorewall6 Providers file
Synopsis
-
/etc/shorewall6/providers
Description
- • You have connections to more than one ISP or multiple connections to the same ISP
- • You run Squid as a transparent proxy on a host other than the firewall.
- • You have other requirements for policy routing.
Each entry in the file defines a single routing table. If you wish to omit a column entry but want to include an entry in the next column, use "-" for the omitted entry. The columns in the file are as follows. NAME – name
- The provider name. Must be a valid shell variable name. The names ‘local’, ‘main’, ‘default’ and ‘unspec’ are reserved and may not be used as provider names.
NUMBER – number
- The provider number — a number between 1 and 15. Each provider must be assigned a unique value.
MARK (Optional) – value
- A FWMARK value used in your m[blue]
shorewall6-manglem[][1](5) file to direct packets to this provider. If HIGH_ROUTE_MARKS=Yes in m[blue]shorewall6.confm[][2](5), then the value must be a multiple of 256 between 256 and 65280 or their hexadecimal equivalents (0x0100 and 0xff00 with the low-order byte of the value being zero). Otherwise, the value must be between 1 and 255. Each provider must be assigned a unique mark value. This column may be omitted if you don’t use packet marking to direct connections to a particular provider.
DUPLICATE – routing-table-name
- The name of an existing table to duplicate to create this routing table. May be
mainor the name of a previously listed provider. You may select only certain entries from the table to copy by using the COPY column below.
INTERFACE – interface
- The name of the network interface to the provider. Must be listed in m[blue]
shorewall6-interfacesm[][3](5).
GATEWAY – {–|address|detect|none}
- The IP address of the provider’s gateway router. You can enter
detecthere and Shorewall6 will attempt to detect the gateway automatically. Beginning with Shorewall 5.0.6, you may also enternone. This causes creation of a routing table with no default route in it. For PPP devices, you may omit this column.
OPTIONS (Optional) – [–|option[,option]…]
- A comma-separated list selected from the following. The order of the options is not significant but the list may contain no embedded white-space. autosrc
- Added in Shorewall 4.5.17. Causes a host route to the provider’s gateway router to be added to the provider’s routing table. This is the default behavior unless overridden by a following
noautosrcoption.
balance[=weight]- Added in Shorewall 4.4.25. The providers that have
balancespecified will get outbound traffic load-balanced among them. By default, all interfaces withbalancespecified will have the same weight (1). Beginning with Shorewall 5.0.13, you can change the weight of an interface by specifyingbalance=weight where weight is the weight of the route out of this interface. Prior to Shorewall 5.0.13, only one provider can specify this option.
fallback[=weight]- Added in Shorewall 4.4.25. Indicates that a default route through the provider should be added to the default routing table (table 253). If a weight is given, a balanced route is added with the weight of this provider equal to the specified weight. If the option is given without a weight, an separate default route is added through the provider’s gateway; the route has a metric equal to the provider’s NUMBER. Prior to Shorewall 5.0.13, at most one provider can specify this option and a weight may not be given.
track- If specified, inbound connections on this interface are to be tracked so that responses may be routed back out this same interface. You want to specify
trackif internet hosts will be connecting to local servers through this provider. Beginning with Shorewall 4.4.3,trackdefaults to the setting of the TRACK_PROVIDERS option in m[blue]shorewall6.confm[][4] (5). If you set TRACK_PROVIDERS=Yes and want to override that setting for an individual provider, then specifynotrack(see below).
loose- Shorewall6 normally adds a routing rule for each IP address on an interface which forces traffic whose source is that IP address to be sent using the routing table for that interface. Setting
looseprevents creation of such rules on this interface.
load=probability- Added in Shorewall 4.6.0. This option provides an alternative method of load balancing based on probabilities. Providers to be balanced are given a probability (a number 0 > n >= 1) with up to 8 digits to the right of the decimal point. Beginning with Shorewall 4.6.10, a warning is issued if the sum of the probabilities is not 1.00000000.
noautosrc- Added in Shorewall 4.5.17. Prevents the addition of a host route to the provider’s gateway router from being added to the provider’s routing table. This option must be used with caution as it can cause start and restart failures.
notrack- Added in Shorewall 4.4.3. When specified, turns off
track.
optional(deprecated for use with providers that do not share an interface)- If the interface named in the INTERFACE column is not up and configured with an IPv4 address then ignore this provider. If not specified, the value of the
optionaloption for the INTERFACE in m[blue]shorewall6-interfaces(5)m[][3] is assumed. Use of that option is preferred to this one, unless an address is provider in the INTERFACE column.
primary- Added in Shorewall 4.6.6,
primaryis a synonym forbalance(see above) and is preferred when the remaining providers specifyfallbackortproxy.
src=source-address
- Specifies the source address to use when routing to this provider and none is known (the local client has bound to the 0 address). May not be specified when an address is given in the INTERFACE column. If this option is not used, Shorewall6 substitutes the primary IP address on the interface named in the INTERFACE column.
mtu=number
- Specifies the MTU when forwarding through this provider. If not given, the MTU of the interface named in the INTERFACE column is assumed.
tproxy- Added in Shorewall 4.5.4. Used for supporting the TPROXY action in shorewall-tcrules(5). See m[blue]
http://www.shorewall.net/Shorewall_Squid_Usage.htmlm[][5]. When specified, the MARK, DUPLICATE and GATEWAY columns should be empty, INTERFACE should be set to ‘lo’ andtproxyshould be the only OPTION. Only onetproxyprovider is allowed.
hostroute- Added in Shorewall 4.5.21. This is the default behavior that results in a host route to the defined
GATEWAYbeing inserted into the main routing table and into the provider’s routing table.hostrouteis required for older distributions butnohostroute(below) is appropriate for recent distributions.hostroutemay interfere with Zebra’s ability to add routes on some distributions such as Debian 7.
nohostroute- Added in Shorewall 4.5.21. nohostroute inhibits addition of a host route to the defined
GATEWAYbeing inserted into the main routing table and into the provider’s routing table.nohostrouteis not appropriate for older distributions but is appropriate for recent distributions.nohostrouteallows Zebra’s to correctly add routes on some distributions such as Debian 7.
persistent- Added in Shorewall 5.0.2 and alters the behavior of the
disablecommand:- • The provider’s routing table still contains the apprioriate default route.
- • Unless the
noautosrcoption is specified, routing rules are generated to route traffic from the interfaces address(es) out of the provider’s routing table.
- • Persistent routing rules in m[blue]
shorewall6-rtrules(5)m[][6] are present.
-
Note
The generated script will attempt to reenable a disabled persistent provider during execution of thestart,restartandreloadcommands. Whenpersistentis not specified, only theenableandreenablecommands can reenable the provider.COPY– [{none|interface[,interface]…}]- A comma-separated list of other interfaces on your firewall. Wildcards specified using an asterisk ("*") are permitted (e.g., tun* ). Usually used only when DUPLICATE is
main. Only copy routes through INTERFACE and through interfaces listed here. If you only wish to copy routes through INTERFACE, enternonein this column. Beginning with Shorewall 4.5.17, blackhole, unreachable and prohibit routes are no longer copied by default but may be copied by includingblackhole,unreachableandprohibitrespectively in the COPY list.
Examples
Example 1:
- You run squid in your DMZ on IP address 2002:ce7c:92b4:1::2. Your DMZ interface is eth2
-
#NAME NUMBER MARK DUPLICATE INTERFACE GATEWAY OPTIONS Squid 1 1 - eth2 2002:ce7c:92b4:1::2 -
-
Example 2:
- eth0 connects to ISP 1. The ISP’s gateway router has IP address 2001:ce7c:92b4:1::2.
eth1 connects to ISP 2. The ISP’s gateway router has IP address 2001:d64c:83c9:12::8b.
eth2 connects to a local network.
-
#NAME NUMBER MARK DUPLICATE INTERFACE GATEWAY OPTIONS COPY ISP1 1 1 main eth0 2001:ce7c:92b4:1::2 track eth2 ISP2 2 2 main eth1 2001:d64c:83c9:12::8b track eth2
-
Files
/etc/shorewall6/providers
See Also
m[blue]
http://www.shorewall.net/MultiISP.htmlm[][7]m[blue]
http://www.shorewall.net/configuration_file_basics.htm#Pairsm[][8]shorewall6(8), shorewall6-accounting(5), shorewall6-actions(5), shorewall6-blacklist(5), shorewall6-hosts(5), shorewall6-interfaces(5), shorewall6-maclist(5), shorewall6-netmap(5),shorewall6-params(5), shorewall6-policy(5), shorewall6-rtrules(5), shorewall6-routestopped(5), shorewall6-rules(5), shorewall6.conf(5), shorewall6-secmarks(5), shorewall6-tcclasses(5), shorewall6-tcdevices(5), shorewall6-mangle(5), shorewall6-tos(5), shorewall6-tunnels(5), shorewall6-zones(5)
Notes
- 1.
- shorewall6-mangle
- 2.
- shorewall6.conf
- 3.
- shorewall6-interfaces
- 4.
- shorewall6.conf
- 5.
- http://www.shorewall.net/Shorewall_Squid_Usage.html
- 6.
- shorewall6-rtrules(5)
- 7.
- http://www.shorewall.net/MultiISP.html
- 8.
- http://www.shorewall.net/configuration_file_basics.htm#Pairs
- A comma-separated list of other interfaces on your firewall. Wildcards specified using an asterisk ("*") are permitted (e.g., tun* ). Usually used only when DUPLICATE is
- Added in Shorewall 4.5.17. Causes a host route to the provider’s gateway router to be added to the provider’s routing table. This is the default behavior unless overridden by a following
