Automate Vultr Snapshots Using Bash
API
v1 end of life was announced June 30, 2023
data:image/s3,"s3://crabby-images/16a73/16a73402b1d3d7353a3ec0be7fc3363699a31bee" alt="Vultr Snapshot Dashboard Vultr Snapshot Dashboard"
Vultr is a VPS (Virtual Private Server) hosting
platform that uses KVM (Kernel–based Virtual Machine) virtualization. Signing
into their website over and over again to make a snapshot can be tedious. Let’s
automate this process using
bash
, and
systemd
timers.
Vultr offers an excellent
API
(Application Programming Interface) that
lets you programmatically orchestrate a web based hypervisor dashboard, right
down to account payments. We will use this API
to automatically create
snapshots.
Update: Vultr’s $0.05/GB
per month. Keeping this in mind the script below sets an
11
free
snapshots.
11
snapshots.
data:image/s3,"s3://crabby-images/79811/79811b33e73cfc291217590acf548014631652bd" alt="Vultr Snapshot Disclaimer Vultr Snapshot Disclaimer"
First let’s set up the variables that our script will use to create and rotate snapshots.
bash
#!/bin/sh -eu
Key='YourAPIKEY'
SnapshotLimit=11
SnapshotCount=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep -o SNAPSHOTID | wc -l)
Fields=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep -o '"' | wc -l)
LastSnapshotField=$((Fields - 24))
LastSnapshotID=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep '"' | cut -d '"' -f $LastSnapshotField)
We are using command substitutions with curl
. Let’s add our API
key and set
the snapshot limit to 11
. The API
will respond in json
. We can install
jq but I’ll use the tools that are available
to process the output. First, we’ll get the current number of snapshots using
grep
and wc
.
bash
SnapshotCount=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep -o SNAPSHOTID | wc -l)
Then use the same technique to get the number of fields in the json
output
delimited by "
.
bash
Fields=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep -o '"' | wc -l)
Since we have an upper snapshot limit of 11
, we also need to know the ID
of
the oldest snapshot. This will allow us to destroy that snapshot when we reach
the limit automatically. I already know that the oldest snapshot ID
is always
28
fields away from the end of the delimited json
output.
bash
LastSnapshotField=$((Fields - 28)
Finish up by using grep
and cut
to extract the oldest snapshot ID
.
bash
LastSnapshotID=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep '"' | cut -d '"' -f $LastSnapshotField)
Execute a simple if
statement to destroy that snapshot when necessary. Nothing
fancy.
bash
if [ "$SnapshotCount" -eq "$SnapshotLimit" ]
then
curl -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/destroy --data "SNAPSHOTID=$LastSnapshotID" || exit 1;
fi
curl -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/create --data 'SUBID=YourSUBID';
Our full script now looks like this and is complete.
bash
#!/bin/sh -eu
Key='YourAPIKEY'
SnapshotLimit=11
SnapshotCount=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep -o SNAPSHOTID | wc -l)
Fields=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep -o '"' | wc -l)
LastSnapshotField=$((Fields - 24))
LastSnapshotID=$(curl -s -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/list | grep '"' | cut -d '"' -f $LastSnapshotField)
if [ "$SnapshotCount" -eq "$SnapshotLimit" ]
then
curl -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/destroy --data "SNAPSHOTID=$LastSnapshotID" || exit 1;
fi
curl -H "API-Key: $Key" https://api.vultr.com/v1/snapshot/create --data 'SUBID=YourSUBID';
Let’s drop this into a systemd
service at
/etc/systemd/system/vultr-snapshot.service
.
ini
[Unit]
Description=Create Vultr Snapshot
[Service]
Type=oneshot
ExecStart=/usr/local/bin/vultr-snapshot
Then run it using a timer at /etc/systemd/system/vultr-snapshot.timer
. This
timer runs the script at 5:30 AM
every morning.
ini
[Unit]
Description=Create Vultr Snapshot
[Timer]
OnCalendar=*-*-* 05:30:00
RandomizedDelaySec=60
[Install]
WantedBy=timers.target
That’s it. This is a quick way of supplementing your normal backups with automatic Vultr snapshots.