mirror of
https://github.com/libguestfs/libguestfs.git
synced 2026-03-21 22:53:37 +00:00
lib: Remove drive hotplugging support
This was a feature that allowed you to add drives to the appliance after launching it. It was complicated to implement, and only worked for the libvirt backend (not "direct", which is the default backend). It also turned out to be a bad idea. The original concept was that appliance creation was slow, so to examine multiple guests you should launch the handle once then hot-add the disks from each guest in turn to manipulate them. However this is terrible from a security point of view, especially for multi-tenant, because the drives from one guest might compromise the appliance and thus the filesystems/drives from subsequent guests. It also turns out that hotplugging is very slow. Nowadays appliance creation should be faster than hotplugging. The main use case for this was virt-df, but virt-df no longer uses it after we discovered the problems outlined above.
This commit is contained in:
@@ -415,14 +415,6 @@ endif
|
||||
TESTS += gdisk/test-expand-gpt.pl
|
||||
EXTRA_DIST += gdisk/test-expand-gpt.pl
|
||||
|
||||
TESTS += \
|
||||
hotplug/test-hot-add.pl \
|
||||
hotplug/test-hot-remove.pl
|
||||
EXTRA_DIST += \
|
||||
hotplug/test-hot-add.pl \
|
||||
hotplug/test-hot-remove.pl \
|
||||
hotplug/test-hotplug-repeated.pl
|
||||
|
||||
# Test uses the Python SimpleHTTPServer module which is
|
||||
# conveniently part of Python core.
|
||||
|
||||
|
||||
@@ -1,63 +0,0 @@
|
||||
#!/usr/bin/env perl
|
||||
# Copyright (C) 2012 Red Hat Inc.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
# Test hot-adding disks.
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use Sys::Guestfs;
|
||||
|
||||
my $g = Sys::Guestfs->new ();
|
||||
|
||||
exit 77 if $ENV{SKIP_TEST_HOT_ADD_PL};
|
||||
|
||||
# Skip the test if the default backend isn't libvirt, since only
|
||||
# the libvirt backend supports hotplugging.
|
||||
my $backend = $g->get_backend ();
|
||||
unless ($backend eq "libvirt" || $backend =~ /^libvirt:/) {
|
||||
print "$0: test skipped because backend ($backend) is not libvirt\n";
|
||||
exit 77
|
||||
}
|
||||
|
||||
# We don't need to add disks before launch.
|
||||
$g->launch ();
|
||||
|
||||
# Create some temporary disks.
|
||||
$g->disk_create ("test-hot-add-1.img", "raw", 512 * 1024 * 1024);
|
||||
$g->disk_create ("test-hot-add-2.img", "raw", 512 * 1024 * 1024);
|
||||
$g->disk_create ("test-hot-add-3.img", "qcow2", 1024 * 1024 * 1024,
|
||||
preallocation => "metadata");
|
||||
|
||||
# Hot-add them. Labels are required.
|
||||
$g->add_drive ("test-hot-add-1.img", label => "a"); # autodetect format
|
||||
$g->add_drive ("test-hot-add-2.img", label => "b", format => "raw", readonly => 1);
|
||||
$g->add_drive ("test-hot-add-3.img", label => "c", format => "qcow2");
|
||||
|
||||
# Check we can use the disks immediately.
|
||||
$g->part_disk ("/dev/disk/guestfs/a", "mbr");
|
||||
$g->mkfs ("ext2", "/dev/disk/guestfs/c");
|
||||
$g->mkfs ("ext2", "/dev/disk/guestfs/a1");
|
||||
|
||||
$g->shutdown ();
|
||||
$g->close ();
|
||||
|
||||
unlink "test-hot-add-1.img";
|
||||
unlink "test-hot-add-2.img";
|
||||
unlink "test-hot-add-3.img";
|
||||
|
||||
exit 0
|
||||
@@ -1,85 +0,0 @@
|
||||
#!/usr/bin/env perl
|
||||
# Copyright (C) 2012 Red Hat Inc.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
# Test hot-adding and -removing disks.
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use Sys::Guestfs;
|
||||
|
||||
my $g = Sys::Guestfs->new ();
|
||||
|
||||
exit 77 if $ENV{SKIP_TEST_HOT_REMOVE_PL};
|
||||
|
||||
# Skip the test if the default backend isn't libvirt, since only
|
||||
# the libvirt backend supports hotplugging.
|
||||
my $backend = $g->get_backend ();
|
||||
unless ($backend eq "libvirt" || $backend =~ /^libvirt:/) {
|
||||
print "$0: test skipped because backend ($backend) is not libvirt\n";
|
||||
exit 77
|
||||
}
|
||||
|
||||
# Create some temporary disks.
|
||||
$g->disk_create ("test-hot-remove-1.img", "raw", 512 * 1024 * 1024);
|
||||
$g->disk_create ("test-hot-remove-2.img", "raw", 512 * 1024 * 1024);
|
||||
$g->disk_create ("test-hot-remove-3.img", "qcow2", 1024 * 1024 * 1024,
|
||||
preallocation => "metadata");
|
||||
|
||||
# Hot-add them. Labels are required.
|
||||
$g->add_drive ("test-hot-remove-1.img", label => "a"); # autodetect format
|
||||
$g->add_drive ("test-hot-remove-2.img", label => "b", format => "raw", readonly => 1);
|
||||
$g->add_drive ("test-hot-remove-3.img", label => "c", format => "qcow2");
|
||||
|
||||
# Remove them (before launch).
|
||||
$g->remove_drive ("a");
|
||||
$g->remove_drive ("b");
|
||||
$g->remove_drive ("c");
|
||||
|
||||
$g->launch ();
|
||||
|
||||
# There should be no drives yet.
|
||||
my @devices = $g->list_devices ();
|
||||
die unless 0 == @devices;
|
||||
|
||||
# Add them again (after launch).
|
||||
$g->add_drive ("test-hot-remove-1.img", label => "a"); # autodetect format
|
||||
$g->add_drive ("test-hot-remove-2.img", label => "b", format => "raw", readonly => 1);
|
||||
$g->add_drive ("test-hot-remove-3.img", label => "c", format => "qcow2");
|
||||
|
||||
# Check we can use the disks immediately.
|
||||
$g->part_disk ("/dev/disk/guestfs/a", "mbr");
|
||||
$g->mkfs ("ext2", "/dev/disk/guestfs/c");
|
||||
$g->mkfs ("ext2", "/dev/disk/guestfs/a1");
|
||||
|
||||
# Remove them (hotplug this time).
|
||||
$g->remove_drive ("a");
|
||||
$g->remove_drive ("b");
|
||||
$g->remove_drive ("c");
|
||||
|
||||
# There should be no drives remaining.
|
||||
@devices = $g->list_devices ();
|
||||
die unless 0 == @devices;
|
||||
|
||||
$g->shutdown ();
|
||||
$g->close ();
|
||||
|
||||
unlink "test-hot-remove-1.img";
|
||||
unlink "test-hot-remove-2.img";
|
||||
unlink "test-hot-remove-3.img";
|
||||
|
||||
exit 0
|
||||
@@ -1,56 +0,0 @@
|
||||
#!/usr/bin/env perl
|
||||
# Copyright (C) 2012 Red Hat Inc.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation; either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
# Test repeatedly hotplugging a single disk.
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use Sys::Guestfs;
|
||||
|
||||
my $g = Sys::Guestfs->new ();
|
||||
|
||||
# Skip the test if the default backend isn't libvirt, since only
|
||||
# the libvirt backend supports hotplugging.
|
||||
my $backend = $g->get_backend ();
|
||||
unless ($backend eq "libvirt" || $backend =~ /^libvirt:/) {
|
||||
print "$0: test skipped because backend ($backend) is not libvirt\n";
|
||||
exit 77
|
||||
}
|
||||
|
||||
$g->launch ();
|
||||
|
||||
# Create a temporary disk.
|
||||
$g->disk_create ("test-hotplug-repeated.img", "raw", 512 * 1024 * 1024);
|
||||
|
||||
my $start_t = time ();
|
||||
while (time () - $start_t <= 60) {
|
||||
$g->add_drive ("test-hotplug-repeated.img",
|
||||
label => "a", format => "raw");
|
||||
$g->remove_drive ("a");
|
||||
}
|
||||
|
||||
# There should be no drives remaining.
|
||||
my @devices = $g->list_devices ();
|
||||
die unless 0 == @devices;
|
||||
|
||||
$g->shutdown ();
|
||||
$g->close ();
|
||||
|
||||
unlink "test-hotplug-repeated.img";
|
||||
|
||||
exit 0
|
||||
Reference in New Issue
Block a user