Skip to content

Latest commit

 

History

History
542 lines (482 loc) · 28.3 KB

instance.md

File metadata and controls

542 lines (482 loc) · 28.3 KB

instance

Manage Linode Instances, Configs, and Disks.

Minimum Required Fields

Field Type Required Description
api_token str Required The Linode account personal access token. It is necessary to run the module.
It can be exposed by the environment variable LINODE_API_TOKEN instead.
See details in Usage.

Examples

- name: Create a new Linode instance.
  linode.cloud.instance:
    label: my-linode
    type: g6-nanode-1
    region: us-east
    image: linode/ubuntu22.04
    root_pass: verysecurepassword!!!
    private_ip: false
    authorized_keys:
      - "ssh-rsa ..."
    stackscript_id: 1337
    stackscript_data:
      variable: value
    group: app
    tags:
      - env=prod
    state: present
- name: Create a new Linode instance with an additional public IPv4 address.
  linode.cloud.instance:
    label: my-linode
    type: g6-nanode-1
    region: us-east
    image: linode/ubuntu22.04
    root_pass: verysecurepassword!!!
    private_ip: false
    authorized_keys:
      - "ssh-rsa ..."
    stackscript_id: 1337
    stackscript_data:
      variable: value
    group: app
    tags:
      - env=prod
    state: present
    additional_ipv4:
      - public: true
- name: Create a Linode Instance with explicit configs and disks.
  linode.cloud.instance:
    label: 'my-complex-instance'
    region: us-southeast
    type: g6-standard-1
    booted: true
    boot_config_label: boot-config
    state: present
    disks:
      - label: boot
        image: linode/ubuntu22.04
        size: 3000
        root_pass: ans1ble-test!
      - label: swap
        filesystem: swap
        size: 512
    configs:
      - label: boot-config
        root_device: /dev/sda
        devices:
          sda:
            disk_label: boot
          sdb:
            disk_label: swap
        state: present
- name: Create a Linode Instance with custom user data.
  linode.cloud.instance:
    label: 'my-metadata-instance'
    region: us-southeast
    type: g6-standard-1
    image: linode/ubuntu22.04
    root_pass: verysecurepassword!!!
    metadata:
      user_data: myuserdata
    state: present
- name: Create a new Linode instance under a placement group.
  linode.cloud.instance:
    label: my-linode
    type: g6-nanode-1
    region: us-east
    placement_group: 
      id: 123
      compliant_only: false
    state: present
- name: Delete a Linode instance.
  linode.cloud.instance:
    label: my-linode
    state: absent

Parameters

Field Type Required Description
state str Required The desired state of the target. (Choices: present, absent)
label str Optional The unique label to give this instance.
type str Optional The Linode Type of the Linode you are creating.
region str Optional The location to deploy the instance in. See the Linode API documentation.
image str Optional The image ID to deploy the instance disk from. (Conflicts With: disks,configs)
authorized_keys list Optional A list of SSH public key parts to deploy for the root user.
root_pass str Optional The password for the root user. If not specified, one will be generated. This generated password will be available in the task success JSON.
stackscript_id int Optional The ID of the StackScript to use when creating the instance. See the Linode API documentation.
stackscript_data dict Optional An object containing arguments to any User Defined Fields present in the StackScript used when creating the instance. Only valid when a stackscript_id is provided. See the Linode API documentation.
firewall_id int Optional The ID of a Firewall this Linode to assign this Linode to.
private_ip bool Optional If true, the created Linode will have private networking enabled.
group str Optional The group that the instance should be marked under. Please note, that group labelling is deprecated but still supported. The encouraged method for marking instances is to use tags. (Updatable)
boot_config_label str Optional The label of the config to boot from.
configs (sub-options) list Optional A list of Instance configs to apply to the Linode. See the Linode API documentation. (Updatable; Conflicts With: image,interfaces)
disks (sub-options) list Optional A list of Disks to create on the Linode. See the Linode API documentation. (Updatable; Conflicts With: image,interfaces)
interfaces (sub-options) list Optional A list of network interfaces to apply to the Linode. See the Linode API documentation. (Conflicts With: disks,configs)
booted bool Optional Whether the new Instance should be booted. This will default to True if the Instance is deployed from an Image or Backup.
backup_id int Optional The id of the Backup to restore to the new Instance. May not be provided if "image" is given.
metadata (sub-options) dict Optional Fields relating to the Linode Metadata service.
backups_enabled bool Optional Enroll Instance in Linode Backup service.
wait bool Optional Wait for the instance to have status "running" before returning. (Default: True)
wait_timeout int Optional The amount of time, in seconds, to wait for an instance to have status "running". (Default: 1500)
additional_ipv4 (sub-options) list Optional Additional ipv4 addresses to allocate.
rebooted bool Optional If true, the Linode Instance will be rebooted. NOTE: The instance will only be rebooted if it was previously in a running state. To ensure your Linode will always be rebooted, consider also setting the booted field. (Default: False)
migration_type str Optional The type of migration to use for Region and Type migrations. (Choices: cold, warm; Default: cold)
auto_disk_resize bool Optional Whether implicitly created disks should be resized during a type change operation. (Default: False)
tags list Optional An array of tags applied to this object. Tags are for organizational purposes only. (Updatable)
placement_group (sub-options) dict Optional A Placement Group to create this Linode under.

configs

Field Type Required Description
devices (sub-options) dict Required The devices to map to this configuration.
label str Required The label to assign to this config.
comments str Optional Arbitrary User comments on this Config. (Updatable)
helpers (sub-options) dict Optional Helpers enabled when booting to this Linode Config.
kernel str Optional A Kernel ID to boot a Linode with. Defaults to "linode/latest-64bit". (Updatable)
memory_limit int Optional Defaults to the total RAM of the Linode. (Updatable)
root_device str Optional The root device to boot. (Updatable)
run_level str Optional Defines the state of your Linode after booting. (Updatable)
virt_mode str Optional Controls the virtualization mode. (Choices: paravirt, fullvirt; Updatable)
interfaces (sub-options) list Optional A list of network interfaces to apply to the Linode. See the Linode API documentation. (Updatable)

devices

Field Type Required Description
sda (sub-options) dict Optional The device to be mapped to /dev/sda
sdb (sub-options) dict Optional The device to be mapped to /dev/sdb
sdc (sub-options) dict Optional The device to be mapped to /dev/sdc
sdd (sub-options) dict Optional The device to be mapped to /dev/sdd
sde (sub-options) dict Optional The device to be mapped to /dev/sde
sdf (sub-options) dict Optional The device to be mapped to /dev/sdf
sdg (sub-options) dict Optional The device to be mapped to /dev/sdg
sdh (sub-options) dict Optional The device to be mapped to /dev/sdh

sda

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

sdb

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

sdc

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

sdd

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

sde

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

sdf

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

sdg

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

sdh

Field Type Required Description
disk_label str Optional The label of the disk to attach to this Linode.
disk_id int Optional The ID of the disk to attach to this Linode.
volume_id int Optional The ID of the volume to attach to this Linode.

helpers

Field Type Required Description
devtmpfs_automount bool Optional Populates the /dev directory early during boot without udev.
distro bool Optional Helps maintain correct inittab/upstart console device.
modules_dep bool Optional Creates a modules dependency file for the Kernel you run.
network bool Optional Automatically configures static networking.
updatedb_disabled bool Optional Disables updatedb cron job to avoid disk thrashing.

interfaces

Field Type Required Description
purpose str Required The type of interface. (Choices: public, vlan, vpc)
primary bool Optional Whether this is a primary interface (Default: False)
subnet_id int Optional The ID of the VPC subnet to assign this interface to.
ipv4 dict Optional The IPv4 configuration for this interface. (VPC only)
label str Optional The name of this interface. Required for vlan purpose interfaces. Must be an empty string or null for public purpose interfaces.
ipam_address str Optional This Network Interface’s private IP address in Classless Inter-Domain Routing (CIDR) notation.
ip_ranges list Optional Packets to these CIDR ranges are routed to the VPC network interface. (VPC only)

disks

Field Type Required Description
label str Required The label to give this Disk.
size int Required The size of the Disk in MB. (Updatable)
authorized_keys list Optional A list of SSH public key parts to deploy for the root user.
authorized_users list Optional A list of usernames.
filesystem str Optional The filesystem to create this disk with.
image str Optional An Image ID to deploy the Disk from.
root_pass str Optional The root user’s password on the newly-created Linode.
stackscript_id int Optional The ID of the StackScript to use when creating the instance. See the Linode API documentation.
stackscript_data dict Optional An object containing arguments to any User Defined Fields present in the StackScript used when creating the instance. Only valid when a stackscript_id is provided. See the Linode API documentation.

metadata

Field Type Required Description
user_data str Optional The user-defined data to supply for the Linode through the Metadata service.
user_data_encoded bool Optional Whether the user_data field content is already encoded in Base64. (Default: False)

additional_ipv4

Field Type Required Description
public bool Required Whether the allocated IPv4 address should be public or private.

placement_group

Field Type Required Description
id int Required The id of the placement group.
compliant_only bool Optional Whether the newly added/migrated/resized linode must be compliant for flexible placement groups. (Default: False)

Return Values

  • instance - The instance description in JSON serialized form.

    • Sample Response:
      {
        "alerts": {
          "cpu": 180,
          "io": 10000,
          "network_in": 10,
          "network_out": 10,
          "transfer_quota": 80
        },
        "backups": {
          "enabled": true,
          "last_successful": "2018-01-01T00:01:01",
          "schedule": {
            "day": "Saturday",
            "window": "W22"
          }
        },
        "created": "2018-01-01T00:01:01",
        "group": "Linode-Group",
        "has_user_data": true,
        "hypervisor": "kvm",
        "id": 123,
        "image": "linode/debian11",
        "ipv4": [
          "203.0.113.1",
          "192.0.2.1"
        ],
        "ipv6": "c001:d00d::1337/128",
        "label": "linode123",
        "region": "us-east",
        "specs": {
          "disk": 81920,
          "memory": 4096,
          "transfer": 4000,
          "vcpus": 2
        },
        "status": "running",
        "tags": [
          "example tag",
          "another example"
        ],
        "type": "g6-standard-1",
        "updated": "2018-01-01T00:01:01",
        "watchdog_enabled": true,
        "placement_group": {
          "id": 123,
          "label": "test",
          "affinity_type": "anti_affinity:local",
          "is_strict": true
        }
      }
    • See the Linode API response documentation for a list of returned fields
  • configs - A list of configs tied to this Linode Instance.

    • Sample Response:
      [
        {
          "comments": "This is my main Config",
          "devices": {
            "sda": {
              "disk_id": 124458,
              "volume_id": null
            },
            "sdb": {
              "disk_id": 124458,
              "volume_id": null
            },
            "sdc": {
              "disk_id": 124458,
              "volume_id": null
            },
            "sdd": {
              "disk_id": 124458,
              "volume_id": null
            },
            "sde": {
              "disk_id": 124458,
              "volume_id": null
            },
            "sdf": {
              "disk_id": 124458,
              "volume_id": null
            },
            "sdg": {
              "disk_id": 124458,
              "volume_id": null
            },
            "sdh": {
              "disk_id": 124458,
              "volume_id": null
            }
          },
          "helpers": {
            "devtmpfs_automount": false,
            "distro": true,
            "modules_dep": true,
            "network": true,
            "updatedb_disabled": true
          },
          "id": 23456,
          "interfaces": [
            {
              "ipam_address": "10.0.0.1/24",
              "label": "example-interface",
              "purpose": "vlan"
            }
          ],
          "kernel": "linode/latest-64bit",
          "label": "My Config",
          "memory_limit": 2048,
          "root_device": "/dev/sda",
          "run_level": "default",
          "virt_mode": "paravirt"
        }
      ]
    • See the Linode API response documentation for a list of returned fields
  • disks - A list of disks tied to this Linode Instance.

    • Sample Response:
      [
        {
          "created": "2018-01-01T00:01:01",
          "filesystem": "ext4",
          "id": 25674,
          "label": "Debian 9 Disk",
          "size": 48640,
          "status": "ready",
          "updated": "2018-01-01T00:01:01"
        }
      ]
    • See the Linode API response documentation for a list of returned fields
  • networking - Networking information about this Linode Instance.

    • Sample Response:
      {
        "ipv4": {
          "private": [
            {
              "address": "192.168.133.234",
              "gateway": null,
              "linode_id": 123,
              "prefix": 17,
              "public": false,
              "rdns": null,
              "region": "us-east",
              "subnet_mask": "255.255.128.0",
              "type": "ipv4"
            }
          ],
          "public": [
            {
              "address": "97.107.143.141",
              "gateway": "97.107.143.1",
              "linode_id": 123,
              "prefix": 24,
              "public": true,
              "rdns": "test.example.org",
              "region": "us-east",
              "subnet_mask": "255.255.255.0",
              "type": "ipv4"
            }
          ],
          "reserved": [
            {
              "address": "97.107.143.141",
              "gateway": "97.107.143.1",
              "linode_id": 123,
              "prefix": 24,
              "public": true,
              "rdns": "test.example.org",
              "region": "us-east",
              "subnet_mask": "255.255.255.0",
              "type": "ipv4"
            }
          ],
          "shared": [
            {
              "address": "97.107.143.141",
              "gateway": "97.107.143.1",
              "linode_id": 123,
              "prefix": 24,
              "public": true,
              "rdns": "test.example.org",
              "region": "us-east",
              "subnet_mask": "255.255.255.0",
              "type": "ipv4"
            }
          ]
        },
        "ipv6": {
          "global": {
            "prefix": 124,
            "range": "2600:3c01::2:5000:0",
            "region": "us-east",
            "route_target": "2600:3c01::2:5000:f"
          },
          "link_local": {
            "address": "fe80::f03c:91ff:fe24:3a2f",
            "gateway": "fe80::1",
            "linode_id": 123,
            "prefix": 64,
            "public": false,
            "rdns": null,
            "region": "us-east",
            "subnet_mask": "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff",
            "type": "ipv6"
          },
          "slaac": {
            "address": "2600:3c03::f03c:91ff:fe24:3a2f",
            "gateway": "fe80::1",
            "linode_id": 123,
            "prefix": 64,
            "public": true,
            "rdns": null,
            "region": "us-east",
            "subnet_mask": "ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff",
            "type": "ipv6"
          }
        }
      }
    • See the Linode API response documentation for a list of returned fields