summaryrefslogtreecommitdiff
path: root/doc/rtd/reference/datasources/ec2.rst
blob: 7e2b522a137e1ac2ddd07fc5af992755f90b3860 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
.. _datasource_ec2:

Amazon EC2
**********

The EC2 datasource is the oldest and most widely used datasource that
``cloud-init`` supports. This datasource interacts with a *magic* IP provided
to the instance by the cloud provider (typically this IP is
``169.254.169.254``). At this IP a http server is provided to the
instance so that the instance can make calls to get instance user data and
instance metadata.

Metadata is accessible via the following URL: ::

    GET http://169.254.169.254/2009-04-04/meta-data/
    ami-id
    ami-launch-index
    ami-manifest-path
    block-device-mapping/
    hostname
    instance-id
    instance-type
    local-hostname
    local-ipv4
    placement/
    public-hostname
    public-ipv4
    public-keys/
    reservation-id
    security-groups

User data is accessible via the following URL: ::

    GET http://169.254.169.254/2009-04-04/user-data
    1234,fred,reboot,true | 4512,jimbo, | 173,,,

Note that there are multiple EC2 Metadata versions of this data provided
to instances. ``Cloud-init`` attempts to use the most recent API version it
supports in order to get the latest API features and instance-data. If a given
API version is not exposed to the instance, those API features will be
unavailable to the instance.

+----------------+----------------------------------------------------------+
+ EC2 version    | supported instance-data/feature                          |
+================+==========================================================+
+ **2021-03-23** | Required for Instance tag support. This feature must be  |
|                | enabled individually on each instance. See the           |
|                | `EC2 tags user guide`_.                                  |
+----------------+----------------------------------------------------------+
| **2016-09-02** | Required for secondary IP address support.               |
+----------------+----------------------------------------------------------+
| **2009-04-04** | Minimum supports EC2 API version for metadata and        |
|                | user data.                                               |
+----------------+----------------------------------------------------------+

To see which versions are supported by your cloud provider use the following
URL: ::

    GET http://169.254.169.254/
    1.0
    2007-01-19
    2007-03-01
    2007-08-29
    2007-10-10
    2007-12-15
    2008-02-01
    2008-09-01
    2009-04-04
    ...
    latest


Configuration settings
======================

The following configuration can be set for the datasource in system
configuration (in :file:`/etc/cloud/cloud.cfg` or
:file:`/etc/cloud/cloud.cfg.d/`).

The settings that may be configured are:

``metadata_urls``
-----------------

This list of URLs will be searched for an EC2 metadata service. The first
entry that successfully returns a 200 response for
``<url>/<version>/meta-data/instance-id`` will be selected.

Default: ['http://169.254.169.254', 'http://[fd00:ec2::254]',
'http://instance-data:8773'].

``max_wait``
------------

The maximum amount of clock time in seconds that should be spent searching
``metadata_urls``. A value less than zero will result in only one request
being made, to the first in the list.

Default: 120

``timeout``
-----------

The timeout value provided to ``urlopen`` for each individual http request.
This is used both when selecting a ``metadata_url`` and when crawling the
metadata service.

Default: 50

``apply_full_imds_network_config``
----------------------------------

Boolean (default: True) to allow ``cloud-init`` to configure any secondary
NICs and secondary IPs described by the metadata service. All network
interfaces are configured with DHCP (v4) to obtain a primary IPv4 address and
route. Interfaces which have a non-empty ``ipv6s`` list will also enable
DHCPv6 to obtain a primary IPv6 address and route. The DHCP response (v4 and
v6) return an IP that matches the first element of ``local-ipv4s`` and
``ipv6s`` lists respectively. All additional values (secondary addresses) in
the static IP lists will be added to the interface.

An example configuration with the default values is provided below:

.. code-block:: yaml

   datasource:
     Ec2:
       metadata_urls: ["http://169.254.169.254:80", "http://instance-data:8773"]
       max_wait: 120
       timeout: 50
       apply_full_imds_network_config: true

Notes
=====

 * There are 2 types of EC2 instances, network-wise: Virtual Private
   Cloud (VPC) ones and Classic ones (also known as non-VPC). One major
   difference between them is that Classic instances have their MAC address
   changed on stop/restart operations, so ``cloud-init`` will recreate the
   network config file for EC2 Classic instances every boot. On VPC instances
   this file is generated only on the first boot of the instance.
   The check for the instance type is performed by ``is_classic_instance()``
   method.

 * For EC2 instances with multiple network interfaces (NICs) attached, DHCP4
   will be enabled to obtain the primary private IPv4 address of those NICs.
   Wherever DHCP4 or DHCP6 is enabled for a NIC, a DHCP route-metric will be
   added with the value of ``<device-number + 1> * 100`` to ensure DHCP
   routes on the primary NIC are preferred to any secondary NICs.
   For example: the primary NIC will have a DHCP route-metric of 100,
   the next NIC will have 200.

.. _EC2 tags user guide: https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html#work-with-tags-in-IMDS