.. _deploy-lb:
=============================
Linux bridge mechanism driver
=============================
The Linux bridge mechanism driver uses only Linux bridges and ``veth`` pairs
as interconnection devices. A layer-2 agent manages Linux bridges on each
compute node and any other node that provides layer-3 (routing), DHCP,
metadata, or other network services.
Compatibility with nftables
~~~~~~~~~~~~~~~~~~~~~~~~~~~
`nftables `_ replaces iptables,
ip6tables, arptables and ebtables, in order to provide a single API for all
``Netfilter`` operations. ``nftables`` provides a backwards compatibility set
of tools for those replaced binaries that present the legacy API to the user
while using the new packet classification framework. As reported in
`LP#1915341 `_ and
`LP#1922892 `_, the tool
``ebtables-nft`` is not totally compatible with the legacy API and returns some
errors. To use Linux Bridge mechanism driver in newer operating systems that
use ``nftables`` by default, it is needed to switch back to the legacy tool.
.. code-block:: console
# /usr/bin/update-alternatives --set ebtables /usr/sbin/ebtables-legacy
Since `LP#1922127 `_ and
`LP#1922892 `_ were fixed,
Neutron Linux Bridge mechanism driver is compatible with the ``nftables``
binaries using the legacy API.
.. note::
Just to unravel the possible terminology confusion, these are the three
``Netfilter`` available framework alternatives:
* The legacy binaries (``iptables``, ``ip6tables``, ``arptables`` and
``ebtables``) that use the legacy API.
* The new ``nftables`` binaries that use the legacy API, to help in the
transition to this new framework. Those binaries replicate the same
commands as the legacy one but using the new framework. The binaries
have the same name ended in ``-nft``.
* The new ``nftables`` framework using the new API. All Netfilter
operations are executed using this new API and one single binary, ``nft``.
Currently we support the first two options. The migration (total or partial)
to the new API is tracked in
`LP#1508155 `_.
In order to use the ``nftables`` binaries with the legacy API, it is needed to
execute the following commands.
.. code-block:: console
# /usr/bin/update-alternatives --set iptables /usr/sbin/iptables-nft
# /usr/bin/update-alternatives --set ip6tables /usr/sbin/ip6tables-nft
# /usr/bin/update-alternatives --set ebtables /usr/sbin/ebtables-nft
# /usr/bin/update-alternatives --set arptables /usr/sbin/arptables-nft
The ``ipset`` tool is not compatible with ``nftables``. To disable it,
``enable_ipset`` must be set to ``False`` in the ML2 plugin configuration file
``/etc/neutron/plugins/ml2/ml2_conf.ini``.
.. path /etc/neutron/plugins/ml2/ml2_conf.ini
.. code-block:: ini
[securitygroup]
# ...
enable_ipset = False
.. toctree::
:maxdepth: 2
deploy-lb-provider
deploy-lb-selfservice
deploy-lb-ha-vrrp