93015527f0
This patch adds possibility to configure kill hooks used to kill external processes, like dnsmasq or keepalived. Change-Id: I29dfbedfb7167982323dcff1c4554ee780cc48db Closes-Bug: #1825943
79 lines
3.8 KiB
ReStructuredText
79 lines
3.8 KiB
ReStructuredText
.. _config-services-agent:
|
|
|
|
===================
|
|
Services and agents
|
|
===================
|
|
|
|
A usual neutron setup consists of multiple services and agents running on one
|
|
or multiple nodes (though some setups may not need any agents).
|
|
Each of these services provide some of the networking or API services.
|
|
Among those of special interest are:
|
|
|
|
#. The neutron-server that provides API endpoints and serves as a single point
|
|
of access to the database. It usually runs on the controller nodes.
|
|
#. Layer2 agent that can utilize Open vSwitch, Linux Bridge or other
|
|
vendor-specific technology to provide network segmentation and isolation
|
|
for project networks.
|
|
The L2 agent should run on every node where it is deemed
|
|
responsible for wiring and securing virtual interfaces (usually both
|
|
compute and network nodes).
|
|
#. Layer3 agent that runs on network node and provides east-west and
|
|
north-south routing plus some advanced services such as FWaaS or VPNaaS.
|
|
|
|
Configuration options
|
|
~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
The neutron configuration options are segregated between
|
|
neutron-server and agents. Both services and agents may load the main
|
|
``neutron.conf`` since this file should contain the oslo.messaging
|
|
configuration for internal neutron RPCs and may contain host specific
|
|
configuration, such as file paths. The ``neutron.conf`` contains the
|
|
database, keystone, nova credentials, and endpoints strictly for
|
|
neutron-server to use.
|
|
|
|
In addition, neutron-server may load a plugin-specific configuration file, yet
|
|
the agents should not. As the plugin configuration is primarily site wide
|
|
options and the plugin provides the persistence layer for neutron, agents
|
|
should be instructed to act upon these values through RPC.
|
|
|
|
Each individual agent may have its own configuration file. This file should be
|
|
loaded after the main ``neutron.conf`` file, so the agent configuration takes
|
|
precedence. The agent-specific configuration may contain configurations which
|
|
vary between hosts in a neutron deployment such as the ``local_ip`` for an L2
|
|
agent. If any agent requires access to additional external services beyond the
|
|
neutron RPC, those endpoints should be defined in the agent-specific
|
|
configuration file (for example, nova metadata for metadata agent).
|
|
|
|
External processes run by agents
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Some neutron agents, like DHCP, Metadata or L3, often run external
|
|
processes to provide some of their functionalities. It may be keepalived,
|
|
dnsmasq, haproxy or some other process.
|
|
Neutron agents are responsible for spawning and killing such processes when
|
|
necessary. By default, to kill such processes, agents use a simple ``kill``
|
|
command, but in some cases, like for example when those additional services
|
|
are running inside containers, it may be not a good solution.
|
|
To address this problem, operators should use the ``AGENT`` config group option
|
|
``kill_scripts_path`` to configure a path to where ``kill scripts`` for such
|
|
processes live. By default, it is set to ``/etc/neutron/kill_scripts/``.
|
|
If option ``kill_scripts_path`` is changed in the config to the different
|
|
location, ``exec_dirs`` in ``/etc/rootwrap.conf`` should be changed accordingly.
|
|
If ``kill_scripts_path`` is set, every time neutron has to kill a process,
|
|
for example ``dnsmasq``, it will look in this directory for a file with the name
|
|
``<process_name>-kill``. So for ``dnsmasq`` process it will look for a
|
|
``dnsmasq-kill`` script. If such a file exists there, it will be called
|
|
instead of using the ``kill`` command.
|
|
|
|
Kill scripts are called with two parameters:
|
|
|
|
.. code-block::
|
|
|
|
<process>-kill <sig> <pid>
|
|
|
|
where: ``<sig>`` is the signal, same as with the ``kill`` command, for example
|
|
``9`` or ``SIGKILL``; and ``<pid>`` is pid of the process to kill.
|
|
|
|
This external script should then handle killing of the given process as neutron
|
|
will not call the ``kill`` command for it anymore.
|