aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSilvio Rhatto <rhatto@riseup.net>2020-08-20 22:28:49 -0300
committerSilvio Rhatto <rhatto@riseup.net>2020-08-20 22:28:49 -0300
commit55f2b7e29f9165280a4eda1348dca10e8474400b (patch)
tree33280191e605ee91576a185790b1f598a4dbecd5
parent78224a66dcd529f8859016087aa34657de6154fe (diff)
downloadkvmx-55f2b7e29f9165280a4eda1348dca10e8474400b.tar.gz
kvmx-55f2b7e29f9165280a4eda1348dca10e8474400b.tar.bz2
Fix: kvmx_disposable: determine guest name using a sequential suffix
-rwxr-xr-xkvmx28
1 files changed, 26 insertions, 2 deletions
diff --git a/kvmx b/kvmx
index 8667405..885ebec 100755
--- a/kvmx
+++ b/kvmx
@@ -2185,8 +2185,32 @@ function kvmx_create {
# Disposable guest
function kvmx_disposable {
- local date="`date +%Y%m%d%I%M%S`"
- local disposable="$VM-disposable-$date"
+ # Determine guest name by appending the current date
+ # This approache leads to the following UNIX socket error
+ # if the VM name is too long:
+ #
+ # UNIX socket path '/var/cache/qemu/.../monitor' is too long
+ # Path must be less than 108 bytes
+ #
+ #local date="`date +%Y%m%d%I%M%S`"
+ #local disposable="$VM-disposable-$date"
+
+ local disposable="$VM-disposable-"
+ local count=0
+
+ # Determine guest name using a sequential suffix
+ #
+ # This results in smaller guest names which are les prone to
+ # the UNIX socket path issue and also is easier to type
+ while true; do
+ disposable="${disposable}${count}"
+ if ! kvmx list_image ${disposable} &> /dev/null; then
+ break
+ fi
+
+ echo $count
+ let count++
+ done
# Clone and ensure we use a backing file
kvmx clone $VM $disposable --skell || exit 1