Corsinvest.ProxmoxVE.AutoSnap.Api
1.8.10
See the version list below for details.
dotnet add package Corsinvest.ProxmoxVE.AutoSnap.Api --version 1.8.10
NuGet\Install-Package Corsinvest.ProxmoxVE.AutoSnap.Api -Version 1.8.10
<PackageReference Include="Corsinvest.ProxmoxVE.AutoSnap.Api" Version="1.8.10" />
paket add Corsinvest.ProxmoxVE.AutoSnap.Api --version 1.8.10
#r "nuget: Corsinvest.ProxmoxVE.AutoSnap.Api, 1.8.10"
// Install Corsinvest.ProxmoxVE.AutoSnap.Api as a Cake Addin #addin nuget:?package=Corsinvest.ProxmoxVE.AutoSnap.Api&version=1.8.10 // Install Corsinvest.ProxmoxVE.AutoSnap.Api as a Cake Tool #tool nuget:?package=Corsinvest.ProxmoxVE.AutoSnap.Api&version=1.8.10
cv4pve-autosnap
Proxmox VE automatic snapshot tool
More information about cv4pve-autosnap
More information about Qemu guest agent
______ _ __
/ ____/___ __________(_)___ _ _____ _____/ /_
/ / / __ \/ ___/ ___/ / __ \ | / / _ \/ ___/ __/
/ /___/ /_/ / / (__ ) / / / / |/ / __(__ ) /_
\____/\____/_/ /____/_/_/ /_/|___/\___/____/\__/
Corsinvest for Proxmox VE Auto Snapshot (Made in Italy)
Usage: cv4pve-autosnap [options] [command]
Options:
-?|-h|--help Show help information
--version Show version information
--host The host name host[:port],host1[:port],host2[:port]
--api-token Api token format 'USER@REALM!TOKENID=UUID'. Require Proxmox VE 6.2 or later
--username User name <username>@<realm>
--password The password. Specify 'file:path_file' to store password in file.
--vmid The id or name VM/CT comma separated (eg. 100,101,102,TestDebian)
-vmid or -name exclude (e.g. -200,-TestUbuntu)
'@pool-???' for all VM/CT in specific pool (e.g. @pool-customer1),
'@all-???' for all VM/CT in specific host (e.g. @all-pve1, @all-\$(hostname)),
'@all' for all VM/CT in cluster
--timeout Timeout operation in seconds
--timestamp-format Specify different timestamp format. Default: yyMMddHHmmss
--max-perc-storage Max percentage storage (default 95%)
Commands:
app-check-update Check update application
app-upgrade Upgrade application
clean Remove auto snapshots
snap Will snap one time
status Get list of all auto snapshots
Run 'cv4pve-autosnap [command] --help' for more information about a command.
cv4pve-autosnap is a part of suite cv4pve-tools.
For more information visit https://www.cv4pve-tools.com
Copyright and License
Copyright: Corsinvest Srl For licensing details please visit LICENSE.md
Commercial Support
This software is part of a suite of tools called cv4pve-tools. If you want commercial support, visit the site
Tutorial
GUI Version Toolbox
Introduction
Automatic snapshot for Proxmox VE with retention.
In this version the tool works outside the Proxmox VE host using the API. The reasons are:
- if the host does not work the tool does not work
- using the API, future changes are guaranteed
- Root access is not required, a user is required to perform the operation
- use of standard https / https json technology
Main features
- Completely written in C#
- Use native Api REST Proxmox VE (library C#)
- Independent os (Windows, Linux, Macosx)
- Installation rapid, unzip file extract binary
- Not require installation in Proxmox VE
- Execute out side Proxmox VE
- For KVM and LXC
- Work for single node or cluster, automatically resolve VM/CT id/name
- Use id or name with --vmid parameter
- Can keep multiple snapshots --keep
- Clean all snapshots
- Multiple schedule VM/CT using --label (es. daily,monthly)
- Hook script
- Multiple VM/CT (100,102,ubuVm,debVm,pipperoVm,fagianoVm or all or pool) in a single execution
- Exclusion specific VM/CT using minus e.g --vmid=all,-100
- Exclusion template from snapshot
- Waiting for the snapshot process to finish
- Alerting in QEMU, agent not enabled.
- Save memory VM Qemu in snap using parameter --state.
- No stop on error
- Script hook for metrics
- Timeout remove/create snapshot in --timeout parameter specify in second
- Support multiple host for HA in --host parameter es. host[:port],host1[:port],host2[:port]
- Multiple output text,unicode,unicodeAlt,markdown,html
- Check-Update and Upgrade application
- Use Api token --api-token parameter
- Support range vmid 100:103,134,200:204,-102
- Support different timestamp format with parameter --timestamp-format
- Check the storage space used by the disks in the VM / CT is available by default (95%) parameter --max-perc-storage
Permission
For execution is required permission: VM.Audit, VM.Snapshot, Datastore.Audit, Pool.Allocate.
Api token
From version 6.2 of Proxmox VE is possible to use Api token. This feature permit execute Api without using user and password. If using Privilege Separation when create api token remember specify in permission.
Custom timestamp format
Timestamp format is based on C# date and time format string.
Configuration and use
E.g. install on linux 64
Download last package e.g. Debian cv4pve-autosnap-linux-x64.zip, on your os and install:
root@debian:~# unzip cv4pve-autosnap-linux-x64.zip
This tool need basically no configuration.
Snapshot a VM/CT one time
root@debian:~# cv4pve-autosnap --host=192.168.0.100 --username=root@pam --password=fagiano --vmid=111 snap --label=daily --keep=2
This command snap VM 111.
root@debian:~# cv4pve-autosnap --host=192.168.0.100 --username=root@pam --password=fagiano --vmid="all,-111" snap --label=daily --keep=2
ACTION Snap
VMs: all,-111
Label: daily
Keep: 2
State: False
Timeout: 30000
Timestamp format: yyMMddHHmmss
Max % Storage : 95%
----------------------------------------------------------------------------
| Storage | Type | Valid | Used % | Max Disk (GB) | Disk (GB) |
----------------------------------------------------------------------------
| cv-pve01/hddpool | zfspool | Ok | 58.2 | 1797 | 1046 |
| cv-pve01/nfs-arc | nfs | Ok | 21.1 | 3269 | 689 |
| cv-pve01/ssdpool | zfspool | Ok | 24.4 | 859 | 209 |
| cv-pve02/hddpool | zfspool | Ok | 71.7 | 1797 | 1288 |
| cv-pve02/nfs-arc | nfs | Ok | 21.1 | 3269 | 689 |
| cv-pve02/ssdpool | zfspool | Ok | 5.5 | 898 | 49 |
----------------------------------------------------------------------------
----- VM 103 Qemu -----
VM 103 consider enabling QEMU agent see https://pve.proxmox.com/wiki/Qemu-guest-agent
Create snapshot: autodaily211203164953
Remove snapshot: autodaily211202164953
VM execution 00:00:02.3060904
----- VM 105 Qemu -----
Create snapshot: autodaily211203164955
Remove snapshot: autodaily211202164955
....
This command snap all VMs except 111.
The --keep tells that it should be kept 2 snapshots, if there are more than 2 snapshots, the 3 one will be erased (sorted by creation time). The --state save memory VM. The --timeout specify the timeout remove/creation snapshot.
When create a snapshot the software add "auto" prefix of the name the snapshot.
On the VM it is checked if "QEMU agent" is enabled, otherwise an alert is displayed.
Clean a VM/CT one time
root@debian:~# cv4pve-autosnap --host=192.168.0.100 --username=root@pam --password=fagiano --vmid=111 clean --label=4hours --keep=2
----- VM 100 QEMU -----
Remove snapshot: auto4hours190617080002
Remove snapshot: auto4hours190617120002
Remove snapshot: auto4hours190617160002
Remove snapshot: auto4hours190617200002
Status snapshots
root@debian:~# cv4pve-autosnap --host=192.168.0.100 --username=root@pam --password=fagiano --vmid=100 status
┌──────┬─────┬───────────────────┬──────────────────────────────┬──────────────────────────────┬─────────────────┬─────┐
│ NODE │ VM │ TIME │ PARENT │ NAME │ DESCRIPTION │ RAM │
├──────┼─────┼───────────────────┼──────────────────────────────┼──────────────────────────────┼─────────────────┼─────┤
│ pve1 │ 100 │ 19/08/28 09:21:35 │ no-parent │ auto4hours190828112133 │ cv4pve-autosnap │ │
│ pve1 │ 100 │ 19/08/28 12:23:09 │ auto4hours190828112133 │ auto4hours190828142307 │ cv4pve-autosnap │ │
│ pve1 │ 100 │ 19/08/29 06:50:23 │ auto4hours190828142307 │ auto4hours190829085021 │ cv4pve-autosnap │ │
│ pve1 │ 100 │ 19/08/29 07:32:15 │ auto4hours190829085021 │ auto4hours190829093214 │ cv4pve-autosnap │ │
└──────┴─────┴───────────────────┴──────────────────────────────┴──────────────────────────────┴─────────────────┴─────┘
Output type:
-o|--output Type output (default: text) Text,Json,JsonPretty
Hook script
Before run hook script, program create environment variable:
CV4PVE_AUTOSNAP_PHASE
CV4PVE_AUTOSNAP_VMID
CV4PVE_AUTOSNAP_VMNAME
CV4PVE_AUTOSNAP_VMTYPE
CV4PVE_AUTOSNAP_LABEL
CV4PVE_AUTOSNAP_KEEP
CV4PVE_AUTOSNAP_SNAP_NAME
CV4PVE_AUTOSNAP_VMSTATE #1/0
CV4PVE_AUTOSNAP_DEBUG #1/0
CV4PVE_AUTOSNAP_DRY_RUN #1/0
CV4PVE_AUTOSNAP_DURATION
CV4PVE_AUTOSNAP_STATE #1/0
See example hook file script-hook.bat, script-hook.sh
Some words about Snapshot consistency and what qemu-guest-agent can do for you
Bear in mind, that when taking a snapshot of a running VM, it's basically like if you have a server which gets pulled away from the Power. Often this is not cathastrophic as the next fsck will try to fix Filesystem Issues, but in the worst case this could leave you with a severely damaged Filesystem, or even worse, half written Inodes which were in-flight when the power failed lead to silent data corruption. To overcome these things, we have the qemu-guest-agent to improve the consistency of the Filesystem while taking a snapshot. It won't leave you a clean filesystem, but it sync()'s outstanding writes and halts all i/o until the snapshot is complete. Still, there might me issues on the Application layer. Databases processes might have unwritten data in memory, which is the most common case. Here you have the opportunity to do additional tuning, and use hooks to tell your vital processes things to do prio and post freezes.
First, you want to make sure that your guest has the qemu-guest-agent running and is working properly. Now we use custom hooks to tell your services with volatile data, to flush all unwritten data to disk. On debian based linux systems the hook file can be set in /etc/default/qemu-guest-agent
and could simply contain this line:
DAEMON_ARGS="-F/etc/qemu/fsfreeze-hook"
Create /etc/qemu/fsfreeze-hook
and make ist look like:
#!/bin/sh
# This script is executed when a guest agent receives fsfreeze-freeze and
# fsfreeze-thaw command, if it is specified in --fsfreeze-hook (-F)
# option of qemu-ga or placed in default path (/etc/qemu/fsfreeze-hook).
# When the agent receives fsfreeze-freeze request, this script is issued with
# "freeze" argument before the filesystem is frozen. And for fsfreeze-thaw
# request, it is issued with "thaw" argument after filesystem is thawed.
LOGFILE=/var/log/qga-fsfreeze-hook.log
FSFREEZE_D=$(dirname -- "$0")/fsfreeze-hook.d
# Check whether file $1 is a backup or rpm-generated file and should be ignored
is_ignored_file() {
case "$1" in
*~ | *.bak | *.orig | *.rpmnew | *.rpmorig | *.rpmsave | *.sample | *.dpkg-old | *.dpkg-new | *.dpkg-tmp | *.dpkg-dist |
*.dpkg-bak | *.dpkg-backup | *.dpkg-remove)
return 0 ;;
esac
return 1
}
# Iterate executables in directory "fsfreeze-hook.d" with the specified args
[ ! -d "$FSFREEZE_D" ] && exit 0
for file in "$FSFREEZE_D"/* ; do
is_ignored_file "$file" && continue
[ -x "$file" ] || continue
printf "$(date): execute $file $@\n" >>$LOGFILE
"$file" "$@" >>$LOGFILE 2>&1
STATUS=$?
printf "$(date): $file finished with status=$STATUS\n" >>$LOGFILE
done
exit 0
For testing purposes place this into /etc/qemu/fsfreeze-hook.d/10-info
:
#!/bin/bash
dt=$(date +%s)
case "$1" in
freeze)
echo "frozen on $dt" | tee >(cat >/tmp/fsfreeze)
;;
thaw)
echo "thawed on $dt" | tee >(cat >>/tmp/fsfreeze)
;;
esac
Now you can place files for different Services in /etc/qemu/fsfreeze-hook.d/
that tell those services what to to prior and post snapshots. A very common example is mysql. Create a file /etc/qemu/fsfreeze-hook.d/20-mysql
containing
#!/bin/sh
# Flush MySQL tables to the disk before the filesystem is frozen.
# At the same time, this keeps a read lock in order to avoid write accesses
# from the other clients until the filesystem is thawed.
MYSQL="/usr/bin/mysql"
#MYSQL_OPTS="-uroot" #"-prootpassword"
MYSQL_OPTS="--defaults-extra-file=/etc/mysql/debian.cnf"
FIFO=/var/run/mysql-flush.fifo
# Check mysql is installed and the server running
[ -x "$MYSQL" ] && "$MYSQL" $MYSQL_OPTS < /dev/null || exit 0
flush_and_wait() {
printf "FLUSH TABLES WITH READ LOCK \\G\n"
trap 'printf "$(date): $0 is killed\n">&2' HUP INT QUIT ALRM TERM
read < $FIFO
printf "UNLOCK TABLES \\G\n"
rm -f $FIFO
}
case "$1" in
freeze)
mkfifo $FIFO || exit 1
flush_and_wait | "$MYSQL" $MYSQL_OPTS &
# wait until every block is flushed
while [ "$(echo 'SHOW STATUS LIKE "Key_blocks_not_flushed"' |\
"$MYSQL" $MYSQL_OPTS | tail -1 | cut -f 2)" -gt 0 ]; do
sleep 1
done
# for InnoDB, wait until every log is flushed
INNODB_STATUS=$(mktemp /tmp/mysql-flush.XXXXXX)
[ $? -ne 0 ] && exit 2
trap "rm -f $INNODB_STATUS; exit 1" HUP INT QUIT ALRM TERM
while :; do
printf "SHOW ENGINE INNODB STATUS \\G" |\
"$MYSQL" $MYSQL_OPTS > $INNODB_STATUS
LOG_CURRENT=$(grep 'Log sequence number' $INNODB_STATUS |\
tr -s ' ' | cut -d' ' -f4)
LOG_FLUSHED=$(grep 'Log flushed up to' $INNODB_STATUS |\
tr -s ' ' | cut -d' ' -f5)
[ "$LOG_CURRENT" = "$LOG_FLUSHED" ] && break
sleep 1
done
rm -f $INNODB_STATUS
;;
thaw)
[ ! -p $FIFO ] && exit 1
echo > $FIFO
;;
*)
exit 1
;;
esac
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
-
net6.0
- Corsinvest.ProxmoxVE.Api.Extension (>= 7.3.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Corsinvest.ProxmoxVE.AutoSnap.Api:
Repository | Stars |
---|---|
Corsinvest/cv4pve-admin
Corsinvest for Proxmox VE Web Admin Clusters - vCenter but for Proxmoxm VE
|
Version | Downloads | Last updated |
---|---|---|
1.8.17 | 134 | 9/19/2024 |
1.8.16 | 166 | 4/19/2024 |
1.8.15 | 822 | 5/5/2023 |
1.8.14 | 380 | 11/3/2022 |
1.8.13 | 430 | 9/13/2022 |
1.8.12 | 445 | 7/11/2022 |
1.8.11 | 462 | 6/1/2022 |
1.8.10 | 452 | 5/4/2022 |
1.8.9 | 426 | 5/3/2022 |
1.8.8 | 448 | 4/27/2022 |
1.8.7 | 445 | 4/26/2022 |
1.8.6 | 705 | 1/27/2022 |
1.8.5 | 324 | 1/4/2022 |
1.8.4 | 336 | 12/6/2021 |
1.8.3 | 307 | 12/5/2021 |
1.8.2 | 306 | 12/3/2021 |
1.8.1 | 354 | 10/31/2021 |
1.8.0 | 382 | 4/28/2021 |
1.7.0 | 409 | 12/16/2020 |
1.6.13 | 396 | 12/15/2020 |
1.6.12 | 464 | 10/19/2020 |
1.6.11 | 396 | 10/12/2020 |
1.6.10 | 431 | 10/5/2020 |
1.6.9 | 402 | 10/2/2020 |
1.6.8 | 459 | 9/30/2020 |
1.6.7 | 478 | 9/28/2020 |
1.6.6 | 466 | 9/28/2020 |
1.6.5 | 439 | 8/24/2020 |
1.6.4 | 460 | 7/30/2020 |
1.6.3 | 484 | 7/23/2020 |
1.6.2 | 432 | 7/17/2020 |
1.6.1 | 459 | 7/14/2020 |
1.6.0 | 492 | 6/20/2020 |
1.5.0 | 478 | 5/12/2020 |
1.4.0 | 730 | 4/16/2020 |
1.3.0 | 454 | 2/25/2020 |
1.2.3 | 500 | 2/21/2020 |
1.2.2 | 557 | 1/30/2020 |
1.2.1 | 479 | 12/27/2019 |
1.2.0 | 497 | 12/21/2019 |
1.1.2 | 563 | 7/4/2019 |
1.1.1 | 518 | 7/4/2019 |
1.1.0 | 534 | 7/4/2019 |