summaryrefslogtreecommitdiff
path: root/man
diff options
context:
space:
mode:
authorThomas Haller <thaller@redhat.com>2020-12-03 18:12:21 +0100
committerThomas Haller <thaller@redhat.com>2020-12-11 17:36:38 +0100
commita4f1fa08938b12bd97c3dde0066ad5a4ceb8055a (patch)
treeb6afd035473552adf1b2b9e377df13a342015e16 /man
parentbe8a3f9902f330bbe8cac58233a7b10bcebd225e (diff)
downloadNetworkManager-a4f1fa08938b12bd97c3dde0066ad5a4ceb8055a.tar.gz
man: add `man 8 nm-cloud-setup`
https://bugzilla.redhat.com/show_bug.cgi?id=1867997 https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/issues/ ## 600
Diffstat (limited to 'man')
-rw-r--r--man/meson.build4
-rw-r--r--man/nm-cloud-setup.xml263
2 files changed, 267 insertions, 0 deletions
diff --git a/man/meson.build b/man/meson.build
index df6e783790..d31d473112 100644
--- a/man/meson.build
+++ b/man/meson.build
@@ -38,6 +38,10 @@ if enable_ovs
mans += [['nm-openvswitch', '7']]
endif
+if enable_nm_cloud_setup
+ mans += [['nm-cloud-setup', '8']]
+endif
+
foreach man: mans
input = man[0] + '.xml'
content_files += join_paths(meson.current_source_dir(), input)
diff --git a/man/nm-cloud-setup.xml b/man/nm-cloud-setup.xml
new file mode 100644
index 0000000000..16c695a97f
--- /dev/null
+++ b/man/nm-cloud-setup.xml
@@ -0,0 +1,263 @@
+<?xml version='1.0'?>
+<?xml-stylesheet type="text/xsl" href="http://docbook.sourceforge.net/release/xsl/current/xhtml/docbook.xsl"?>
+<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
+"http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd" [
+<!ENTITY % entities SYSTEM "common.ent" >
+%entities;
+]>
+
+<!--
+ nm-cloud-setup(8) manual page
+
+ Copyright 2020 Red Hat, Inc.
+
+ Permission is granted to copy, distribute and/or modify this document
+ under the terms of the GNU Free Documentation License, Version 1.1
+ or any later version published by the Free Software Foundation;
+ with no Invariant Sections, no Front-Cover Texts, and no Back-Cover
+ Texts. You may obtain a copy of the GNU Free Documentation License
+ from the Free Software Foundation by visiting their Web site or by
+ writing to:
+
+ Free Software Foundation, Inc.,
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+-->
+
+<refentry id="nm-cloud-setup">
+ <refentryinfo>
+ <title>nm-cloud-setup</title>
+ <author>Automatic Network Configuration in Cloud with NetworkManager</author>
+ </refentryinfo>
+
+ <refmeta>
+ <refentrytitle>nm-cloud-setup</refentrytitle>
+ <manvolnum>8</manvolnum>
+ <refmiscinfo class="source">NetworkManager</refmiscinfo>
+ <refmiscinfo class="manual">Automatic Network Configuration in Cloud with NetworkManager</refmiscinfo>
+ <refmiscinfo class="version">&NM_VERSION;</refmiscinfo>
+ </refmeta>
+
+ <refnamediv>
+ <refname>nm-cloud-setup</refname>
+ <refpurpose>Overview of Automatic Network Configuration in Cloud</refpurpose>
+ </refnamediv>
+
+ <refsect1>
+ <title>Overview</title>
+
+ <para>When running a virtual machine in a public cloud environment, it is
+ desirable to automatically configure the network of that VM.
+ In simple setups, the VM only has one network interface and the public
+ cloud supports automatic configuration via DHCP, DHCP6 or IPv6 autoconf.
+ However, on the virtual machine might have multiple network
+ interfaces, or multiple IP addresses and IP subnets
+ on one interface. Also, the administrator can reconfigure those settings
+ while the machine is running. NetworkManager's nm-cloud-setup is a tool
+ that automatically picks up such configuration and updates the network
+ configuration of the host.</para>
+
+ <para>Multiple cloud providers are supported. See <xref linkend="providers"/>.</para>
+ </refsect1>
+
+ <refsect1>
+ <title>Use</title>
+
+ <para>The goal of nm-cloud-setup is to be configuration-less and work automatically.
+ All you need is to opt-in to the desired cloud providers (see <xref linkend="env"/>)
+ and run <command>/usr/libexec/nm-cloud-setup</command>.</para>
+
+ <para>Usually this is done by enabling the nm-cloud-setup.service systemd service
+ and let it run periodically. For that there is both a nm-cloud-setup.timer systemd timer
+ and a NetworkManager dispatcher script.</para>
+ </refsect1>
+
+ <refsect1>
+ <title>Details</title>
+
+ <para>
+ nm-cloud-setup configures the network by fetching the configuration from
+ the well-known meta data server of the cloud provider. That means, it already
+ needs the network configured to the point where it can reach the meta data
+ server. Commonly that means, that a simple connection profile is activated
+ that possibly uses DHCP to get the primary IP address. NetworkManager will
+ create such a profile for ethernet devices automatically if it is not configured
+ otherwise via <literal>"no-auto-default"</literal> setting in NetworkManager.conf.
+ One possible alternative may be to create such an initial profile with
+ <command>nmcli device connect "$DEVICE"</command> or
+ <command>nmcli connection add type ethernet ...</command>.
+ </para>
+
+ <para>nm-cloud-setup modifies the run time configuration akin to <command>nmcli device modify</command>.
+ With this approach, the configuration is not persisted
+ and only preserved until the device disconnects.</para>
+
+ <refsect2>
+ <title>/usr/libexec/nm-cloud-setup</title>
+
+ <para>The binary <command>/usr/libexec/nm-cloud-setup</command> does most of the
+ work. It supports no command line arguments but can be configured via environment
+ variables.
+ See <xref linkend="env"/> for the supported environment variables.</para>
+
+ <para>By default, all cloud providers are disabled unless you opt-in by enabling one
+ or several providers. If cloud providers are enabled, the program
+ tries to fetch the host's configuration from a meta data server of the cloud via HTTP.
+ If configuration could be not fetched, no cloud provider are detected and the
+ program quits.
+ If host configuration is obtained, the corresponding cloud provider is
+ successfully detected. Then the network of the host will be configured.</para>
+
+ <para>It is intended to re-run nm-cloud-setup every time when the configuration
+ (maybe) changes. The tool is idempotent, so it should be OK to also run it
+ more often than necessary. You could run <command>/usr/libexec/nm-cloud-setup</command>
+ directly. However it may be preferable to restart the nm-cloud-setup systemd
+ service instead or use the timer or dispatcher script to run it periodically (see below).</para>
+ </refsect2>
+
+ <refsect2>
+ <title>nm-cloud-setup.service systemd unit</title>
+ <para>Usually <command>/usr/libexec/nm-cloud-setup</command> is not run directly,
+ but only by <command>systemctl restart nm-cloud-setup.service</command>. This
+ ensures that the tool only runs once at any time. It also allows to integrate
+ use the nm-cloud-setup systemd timer,
+ and to enable/disable the service via systemd.</para>
+
+ <para>As you need to set environment variable to configure nm-cloud-setup binary,
+ you can do so via systemd override files. Try <command>systemctl edit nm-cloud-setup.service</command>.</para>
+ </refsect2>
+
+ <refsect2>
+ <title>nm-cloud-setup.timer systemd timer</title>
+ <para><command>/usr/libexec/nm-cloud-setup</command> is intended to run
+ whenever an update is necessary. For example, during boot when when
+ changing the network configuration of the virtual machine via the cloud
+ provider.</para>
+
+ <para>One way to do this, is by enabling the nm-cloud-setup.timer systemd timer
+ with <command>systemctl enable --now nm-cloud-setup.timer</command>.</para>
+ </refsect2>
+
+ <refsect2>
+ <title>/usr/lib/NetworkManager/dispatcher.d/90-nm-cloud-setup.sh</title>
+
+ <para>There is also a NetworkManager dispatcher script that will
+ run for example when an interface is activated by NetworkManager.
+ Together with the nm-cloud-setup.timer systemd timer this
+ script is to automatically pick up changes to the network.</para>
+
+ <para>The dispatcher script will do nothing, unless the systemd service is
+ enabled. To use the dispatcher script you should therefor run
+ <command>systemctl enable nm-cloud-setup.service</command> once.</para>
+ </refsect2>
+
+ </refsect1>
+
+ <refsect1 id="env">
+ <title>Environment Variables</title>
+
+ <para>The environment variables are used to configure <command>/usr/libexec/nm-cloud-setup</command>.
+ You may want to configure them in the systemd service with <command>systemctl edit nm-cloud-setup.service</command>.</para>
+
+ <itemizedlist>
+ <listitem>
+ <para><literal>NM_CLOUD_SETUP_LOG</literal>: control the logging verbosity. Set it
+ one of <literal>TRACE</literal>, <literal>DEBUG</literal>, <literal>INFO</literal>,
+ <literal>WARN</literal>, <literal>ERR</literal> or <literal>OFF</literal>. The program
+ will print message on stdout and the default level is <literal>WARN</literal>.</para>
+ </listitem>
+ <listitem>
+ <para><literal>NM_CLOUD_SETUP_AZURE</literal>: boolean, whether Microsoft Azure support is enabled. Defaults
+ to <literal>no</literal>.</para>
+ </listitem>
+ <listitem>
+ <para><literal>NM_CLOUD_SETUP_EC2</literal>: boolean, whether Amazon EC2 (AWS) support is enabled. Defaults
+ to <literal>no</literal>.</para>
+ </listitem>
+ <listitem>
+ <para><literal>NM_CLOUD_SETUP_GCP</literal>: boolean, whether Google GCP support is enabled. Defaults
+ to <literal>no</literal>.</para>
+ </listitem>
+ </itemizedlist>
+
+ </refsect1>
+
+ <refsect1 id="providers">
+ <title>Supported Cloud Providers</title>
+
+ <refsect2>
+ <title>Amazon EC2 (AWS)</title>
+
+ <para>The tools tries to fetch configuration from <literal>http://169.254.169.254/</literal>. Currently, it only
+ configures IPv4 and does nothing about IPv6. It will do the following.</para>
+
+ <itemizedlist>
+ <listitem>
+ <para>First fetch <literal>http://169.254.169.254/latest/meta-data/</literal> to determine whether the
+ expected API is present. This determines whether EC2 environment is detected and whether to proceed
+ to configure the host using EC2 meta data.</para>
+ </listitem>
+ <listitem>
+ <para>Fetch <literal>http://169.254.169.254/2018-09-24/meta-data/network/interfaces/macs/</literal> to get the list
+ of available interface. Interfaces are identified by their MAC address.</para>
+ </listitem>
+ <listitem>
+ <para>Then for each interface fetch <literal>http://169.254.169.254/2018-09-24/meta-data/network/interfaces/macs/$MAC/subnet-ipv4-cidr-block</literal>
+ and <literal>http://169.254.169.254/2018-09-24/meta-data/network/interfaces/macs/$MAC/local-ipv4s</literal>.
+ Thereby we get a list of local IPv4 addresses and one CIDR subnet block.</para>
+ </listitem>
+ <listitem>
+ <para>Then nm-cloud-setup iterates over all interfaces for which it could fetch IP configuration.
+ If no ethernet device for the respective MAC address is found, it is skipped.
+ Also, if the device is currently not activated in NetworkManager or if the currently
+ activated profile has a user-data <literal>org.freedesktop.nm-cloud-setup.skip=yes</literal>,
+ it is skipped.</para>
+ <para>Then, the tool will change the runtime configuration of the device.
+ <itemizedlist>
+ <listitem>
+ <para>Add static IPv4 addresses for all the configured addresses from <literal>local-ipv4s</literal> with
+ prefix length according to <literal>subnet-ipv4-cidr-block</literal>. For example,
+ we might have here 2 IP addresses like <literal>"172.16.5.3/24,172.16.5.4/24"</literal>.</para>
+ </listitem>
+ <listitem>
+ <para>Choose a route table 30400 + the index of the interface and
+ add a default route <literal>0.0.0.0/0</literal>. The gateway
+ is the first IP address in the CIDR subnet block. For
+ example, we might get a route <literal>"0.0.0.0/0 172.16.5.1 10 table=30401"</literal>.</para>
+ </listitem>
+ <listitem>
+ <para>Finally, add a policy routing rule for each address. For example
+ <literal>"priority 30401 from 172.16.5.3/32 table 30401, priority 30401 from 172.16.5.4/32 table 30401"</literal>.</para>
+ </listitem>
+ </itemizedlist>
+ With above example, this roughly corresponds for interface <literal>eth0</literal> to
+ <command>nmcli device modify "eth0" ipv4.addresses "172.16.5.3/24,172.16.5.4/24" ipv4.routes "0.0.0.0/0 172.16.5.1 10 table=30401" ipv4.routing-rules "priority 30401 from 172.16.5.3/32 table 30401, priority 30401 from 172.16.5.4/32 table 30401"</command>.
+ Note that this replaces the previous addresses, routes and rules with the new information.
+ But also note that this only changes the run time configuration of the device. The
+ connection profile is not affected by that.
+ </para>
+ </listitem>
+ </itemizedlist>
+ </refsect2>
+
+ <refsect2>
+ <title>Google Cloud Platform (GCP)</title>
+
+ <para>The tools tries to fetch configuration from <literal>http://metadata.google.internal/</literal>.</para>
+ </refsect2>
+
+ <refsect2>
+ <title>Microsoft Azure</title>
+
+ <para>The tools tries to fetch configuration from <literal>http://169.254.169.254/</literal>.</para>
+ </refsect2>
+
+ </refsect1>
+
+ <refsect1>
+ <title>See Also</title>
+ <para>
+ <link linkend='NetworkManager'><citerefentry><refentrytitle>NetworkManager</refentrytitle><manvolnum>8</manvolnum></citerefentry></link>
+ <link linkend='nmcli'><citerefentry><refentrytitle>nmcli</refentrytitle><manvolnum>1</manvolnum></citerefentry></link>
+ </para>
+ </refsect1>
+</refentry>