Run cloud-init locally with LXD

LXD offers a streamlined user experience for using Linux system containers.

Create your configuration

In this example we will create a file called user-data.yaml containing a basic cloud-init configuration:

$ cat >user-data.yaml <<EOF
#cloud-config
password: password
chpasswd:
  expire: False
ssh_pwauth: True
EOF

Initialize a container

With LXD, the following command initializes a container with the user data file we just created:

$ lxc init ubuntu-daily:jammy test-container
$ lxc config set test-container user.user-data - < user-data.yaml
$ lxc start test-container

To avoid the extra commands this can also be done at launch:

$ lxc launch ubuntu-daily:jammy test-container --config=user.user-data="$(cat user-data.yaml)"

Finally, a profile can be set up with the specific data if you need to launch this multiple times:

$ lxc profile create dev-user-data
$ lxc profile set dev-user-data user.user-data - < cloud-init-config.yaml
$ lxc launch ubuntu-daily:jammy test-container -p default -p dev-user-data

LXD configuration types

The above examples all show how to pass user data. To pass other types of configuration data use the configuration options specified below:

Data

Configuration option

user-data

cloud-init.user-data

vendor-data

cloud-init.vendor-data

network config

cloud-init.network-config

See the LXD Instance Configuration docs for more info about configuration values or the LXD Custom Network Configuration document for more about custom network config and using LXD with cloud-init.