2024-03-30 17:01:00 +01:00
|
|
|
# Build Flatcar Snapshots on Hetzner Cloud with Packer
|
|
|
|
|
|
|
|
|
|
## Requirements
|
|
|
|
|
|
2024-04-03 18:27:45 +02:00
|
|
|
- [Hetzner Cloud API Token](https://docs.hetzner.com/cloud/api/getting-started/generating-api-token/)
|
|
|
|
|
- [Packer](https://developer.hashicorp.com/packer)
|
|
|
|
|
- [Butane](https://coreos.github.io/butane/)
|
|
|
|
|
- [Hetzner Cloud CLI](https://github.com/hetznercloud/cli) (`hcloud`)
|
2024-03-30 17:01:00 +01:00
|
|
|
|
2024-04-03 18:27:45 +02:00
|
|
|
This only works on Flatcar version `3913.0.0` (or later), as this version has the appropriate versions of
|
|
|
|
|
`ignition` and `afterburn` that include support for the Hetzner Cloud metadata service.
|
2024-03-30 17:01:00 +01:00
|
|
|
|
|
|
|
|
## Building Snapshots
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
$ git clone ... # TODO
|
2024-04-03 18:27:45 +02:00
|
|
|
$ export HCLOUD_TOKEN=<Your Hetzner Cloud API Token>
|
2024-03-30 17:01:00 +01:00
|
|
|
$ packer init flatcar.pkr.hcl
|
|
|
|
|
$ butane butane-oem.yaml --pretty --strict --output=ignition-oem.json
|
|
|
|
|
|
|
|
|
|
# This will build Snapshots for x86 and arm. If you only need one, you can add
|
|
|
|
|
# `--only=hcloud.x86` or `--only=hcloud.arm` to the `packer build` command.
|
|
|
|
|
$ packer build flatcar.pkr.hcl
|
|
|
|
|
# ... Takes a few minutes
|
|
|
|
|
==> Builds finished. The artifacts of successful builds are:
|
|
|
|
|
--> hcloud.x86: A snapshot was created: 'flatcar-alpha-x86' (ID: 157132241)
|
|
|
|
|
--> hcloud.arm: A snapshot was created: 'flatcar-alpha-arm' (ID: 157132252)
|
|
|
|
|
|
|
|
|
|
$ hcloud image list --type=snapshot --selector=os=flatcar
|
|
|
|
|
ID TYPE NAME DESCRIPTION ARCHITECTURE IMAGE SIZE DISK SIZE CREATED DEPRECATED
|
|
|
|
|
157132241 snapshot - flatcar-alpha-x86 x86 0.47 GB 20 GB Sat Mar 30 16:48:22 CET 2024 -
|
|
|
|
|
157132252 snapshot - flatcar-alpha-arm arm 0.42 GB 40 GB Sat Mar 30 16:48:24 CET 2024 -
|
|
|
|
|
```
|
|
|
|
|
|
2024-04-03 18:27:45 +02:00
|
|
|
## Create a Server
|
2024-03-30 17:01:00 +01:00
|
|
|
|
|
|
|
|
You can now create a new server from the snapshot. Not every feature might automatically work, as the snapshot is
|
|
|
|
|
missing the functionality from [`hc-utils`](https://github.com/hetznercloud/hc-utils). Configuring SSH Keys and User
|
|
|
|
|
Data (Ignition) will work as expected.
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
# Get ID of the most recent flatcar snapshot for x86
|
2024-04-03 11:00:21 +02:00
|
|
|
$ SNAPSHOT_ID=$(hcloud image list --type=snapshot --selector=os=flatcar --architecture=x86 -o=columns=id -o noheader --sort=created:desc | head -n1)
|
2024-03-30 17:01:00 +01:00
|
|
|
|
|
|
|
|
# Create a new server
|
|
|
|
|
# If you have, you can specify an Ignition config with `--user-data-from-file ignition-user.json`
|
|
|
|
|
$ hcloud server create --name flatcar-test --image $SNAPSHOT_ID --type cx11 --ssh-key <your-key>
|
2024-04-03 18:27:45 +02:00
|
|
|
# Wait about a minute or two for the server to be started
|
2024-03-30 17:01:00 +01:00
|
|
|
|
|
|
|
|
# Now you can login, the following is a helper that calls `ssh` with the public ipv4 address of the server
|
|
|
|
|
$ hcloud server ssh flatcar-test
|
|
|
|
|
```
|