Iptables-nft Support
To transparently route TCP traffic through the proxy, without any awareness from the application, Linkerd will configure a set of firewall rules in each injected pod. Configuration can be done either through an init container or through a CNI plugin.
Linkerd’s init container can be run in two separate modes: legacy
or nft
.
The difference between the two modes is what variant of iptables
they will use
to configure firewall rules.
Details
Modes for the init container can be changed either at upgrade time, or during
installation. Once configured, all injected workloads (including the control
plane) will use the same mode in the init container. Both modes will use the
iptables
utility to configure firewall rules; the main difference between the
two, is which binary they will call into:
legacy
mode will call intoiptables-legacy
for firewall configuration. This is the default mode thatlinkerd-init
runs in, and is supported by most operating systems and distributions.nft
mode will call intoiptables-nft
, which uses the newernf_tables
kernel API. Thenftables
utilities are used by newer operating systems to configure firewalls by default.
Conceptually, iptables-nft
is a bridge between the legacy and the newer
nftables
utilities. Under the hood, it uses a different backend, where rules
additions and deletions are atomic. The nft version of iptables uses the same
packet matching syntax (xtables) as its legacy counterpart.
Because both utilities use the same syntax, it is recommended to run in
whatever mode your Kubernetes hosts support best. Certain operating systems
(e.g Google Container Optimized OS) do not offer support out-of-the-box for
nftables
modules. Others (e.g RHEL family of operating systems) do not
support the legacy version of iptables. Linkerd’s init container should be run
in nft
mode only if the nodes support it and contain the relevant nftables
modules.
Installation
The mode for linkerd-init
can be overridden through the configuration option
proxyInit.iptablesMode=iptables|nft
. The configuration option can be used for
both Helm and CLI installations (or upgrades). For example, the following line
will install Linkerd and set the init container mode to nft
:
linkerd install --set "proxyInit.iptablesMode=nft" | kubectl apply -f -