4. Modifying p_w_picpaths
guestfish.......................................................................................................................11
guestmount...................................................................................................................12
virt-*tools.....................................................................................................................13
Loopdevices, kpartx, network block devices.................................................................. 14
Onceyou have obtained a virtual machine p_w_picpath, you may want to make some changes
toit before uploading it to the OpenStack Image service. Here we describe severaltools
availablethat allow you to modify p_w_picpaths.
Warning
Donot attempt to use these tools to modify an p_w_picpath that is attached to a
runningvirtual machine. These tools are designed to only modify p_w_picpaths that
arenot currently running.
guestfish
Theguestfish program is a tool from the libguestfs project that allows you to modify the
filesinside of a virtual machine p_w_picpath.
Notethat guestfish doesn't mount the p_w_picpath directly into the local filesystem.Instead, it
providesyou with a shell interface that allows you to view, edit, and delete files.Many of
theguestfish commands (e.g., touch, chmod, rm) are similar totraditional bash commands.
Example guestfish session
Weoften need to modify a virtual machine p_w_picpath to remove any traces of the MAC
addressthat was assigned to the virtual network interface card when the p_w_picpath was
firstcreated, since the MAC address will be different when it boots the next time.In this
example,we show how we can use guestfish to remove references to the old MAC address
bydeleting the /etc/udev/rules.d/70-persistent-net.rules file and removing
theHWADDR line from the /etc/sysconfig/network-scripts/ifcfg-eth0 file.
Assumewe have a CentOS qcow2 p_w_picpath called centos63_desktop.img. We would
mountthe p_w_picpath in read-write mode by doing, as root:
#guestfish --rw -a centos63_desktop.img
Welcometo guestfish, the libguestfs filesystem interactive shell for
editingvirtual machine filesystems.
Type:'help' for help on commands
'man'to read the manual
'quit'to quit the shell
><fs>
Thisstarts a guestfish session. Note that the guestfish prompt looks like a fish: ><fs>.
ComputeVM Image Guide Sep 6, 2013 current
12
Wemust first use the run command at the guestfish prompt before we can doanything
else.This will launch a virtual machine, which will be used to perform all of thefile
manipulations.
><fs>run
Wecan now view the filesystems in the p_w_picpath using the list-filesystems command:
><fs>list-filesystems
/dev/vda1:ext4
/dev/vg_centosbase/lv_root:ext4
/dev/vg_centosbase/lv_swap:swap
Weneed to mount the logical volume that contains the root partition:
><fs>mount /dev/vg_centosbase/lv_root /
Next,we want to delete a file. We can use the rm guestfish command, whichworks the
sameway it does in a traditional shell.
><fs>rm /etc/udev/rules.d/70-persistent-net.rules
Wewant to edit the ifcfg-eth0 file to remove the HWADDR line. The edit commandwill
copythe file to the host, invoke your editor, and then copy the file back.
><fs>edit /etc/sysconfig/network-scripts/ifcfg-eth0
Le'ssay we want to modify this p_w_picpath to load the 8021q kernel at boot time. We'llneed to
createan executable script in the /etc/sysconfig/modules/ directory. We can use the
touchguestfish command to create an empty file,use the edit command to edit it, and use
thechmod command to make it executable.
><fs>touch /etc/sysconfig/modules/8021q.modules
><fs>edit /etc/sysconfig/modules/8021q.modules
Weadd the following line to the file and save it
modprobe8021q
Thenwe set to executable:
><fs>chmod 0755 /etc/sysconfig/modules/8021q.modules
We'redone, so we can exit using the exit command:
><fs>exit
Going further with guestfish
Thereis an enormous amount of functionality in guestfish and a full treatment isbeyond
thescope of this document. Instead, we recommend that you read the guestfs-recipes
documentationpage for a sense of what is possible with these tools.
guestmount
Forsome types of changes, you may find it easier to mount the p_w_picpath's filesystemdirectly
inthe guest. The guestmount program, also from the libguestfs project,allows you to do
so.
ComputeVM Image Guide Sep 6, 2013 current
13
Forexample, to mount the root partition from our centos63_desktop.qcow2 p_w_picpath to
/mnt,we can do:
#guestmount -a centos63_desktop.qcow2 -m /dev/vg_centosbase/lv_root --rw /mnt
Ifwe didn't know in advance what the mountpoint is in the guest, we could use the-
i(inspect)flag to tell guestmount to automatically determine what mount point to use:
#guestmount -a centos63_desktop.qcow2 -i --rw /mnt
Oncemounted, we could do things like list the installed packages using rpm:
#rpm -qa --dbpath /mnt/var/lib/rpm
Oncedone, we unmount:
#umount /mnt
virt-* tools
Thelibguestfs project has a number of other useful tools,including:
virt-df for displaying free space inside of an p_w_picpath.
virt-resize for resizing an p_w_picpath.
virt-sysprep for preparing an p_w_picpath for distribution(e.g., delete SSH host keys, remove
MACaddress info, remove user accounts).
virt-sparsify for making an p_w_picpath sparse
virt-p2v for converting a physical machine to an p_w_picpaththat runs on KVM
virt-v2v for converting Xen and VMWare p_w_picpaths to KVMp_w_picpaths
Resize an p_w_picpath
Here'sa simple of example of how to use virt-resize to resize an p_w_picpath. Assumewe have a
16GBWindows p_w_picpath in qcow2 format that we want to resize to 50GB. First, we use virtfilesystems
toidentify the partitions:
#virt-filesystems --long --parts --blkdevs -h -a /data/p_w_picpaths/win2012.qcow2
NameType MBR Size Parent
/dev/sda1partition 07 350M /dev/sda
/dev/sda2partition 07 16G /dev/sda
/dev/sdadevice - 16G -
Inthis case, it's the /dev/sda2 partition that we want to resize. We create a newqcow2
p_w_picpathand use the virt-resize command to write a resized copy of the originalinto the new
p_w_picpath
#qemu-img create -f qcow2 /data/p_w_picpaths/win2012-50gb.qcw2 50G
#virt-resize --expand /dev/sda2 /data/p_w_picpaths/win2012.qcow2 /data/p_w_picpaths/
win2012-50gb.qcow2
Examining/data/p_w_picpaths/win2012.qcow2 ...
ComputeVM Image Guide Sep 6, 2013 current
14
**********
Summaryof changes:
/dev/sda1:This partition will be left alone.
/dev/sda2:This partition will be resized from 15.7G to 49.7G. The
filesystemntfs on /dev/sda2 will be expanded using the
'ntfsresize'method.
**********
Settingup initial partition table on /data/p_w_picpaths/win2012-50gb.qcow2 ...
Copying/dev/sda1 ...
100%###################################################################
00:00
Copying/dev/sda2 ...
100%###################################################################
00:00
Expanding/dev/sda2 using the 'ntfsresize' method ...
Resizeoperation completed with no errors. Before deleting the old
disk,carefully check that the resized disk boots and works correctly.
Loop devices, kpartx, network block devices
Ifyou don't have access to libguestfs, you can mount p_w_picpath file systems directlyin the host
usingloop devices, kpartx, and network block devices.
Warning
Mountinguntrusted guest p_w_picpaths using the tools described in this section is a
securityrisk, always use libguestfs tools such as guestfish and guestmount if you
haveaccess to them. See Areminder why you should never mount guest disk
p_w_picpathson the host OS byDaniel Berrangé for more details.
Mounting a raw p_w_picpath (without LVM)
Ifyou have a raw virtual machine p_w_picpath that is not using LVM to manage itspartitions.
First,use the losetup command to find an unused loop device.
#losetup -f
/dev/loop0
Inthis example, /dev/loop0 is free. Associate a loop device with the raw p_w_picpath:
#losetup /dev/loop0 fedora17.img
Ifthe p_w_picpath only has a single partition, you can mount the loop device directly:
#mount /dev/loop0 /mnt
Ifthe p_w_picpath has multiple partitions, use kpartx to expose the partitionsas separate devices
(e.g.,/dev/mapper/loop0p1), then mount the partition that corresponds to the rootfile
system:
#kpartx -av /dev/loop0
ComputeVM Image Guide Sep 6, 2013 current
15
Ifthe p_w_picpath has, say three partitions (/boot, /, /swap), there should be one newdevice
createdper partition:
$ls -l /dev/mapper/loop0p*
brw-rw----1 root disk 43, 49 2012-03-05 15:32 /dev/mapper/loop0p1
brw-rw----1 root disk 43, 50 2012-03-05 15:32 /dev/mapper/loop0p2
brw-rw----1 root disk 43, 51 2012-03-05 15:32 /dev/mapper/loop0p3
Tomount the second partition, as root:
#mkdir /mnt/p_w_picpath
#mount /dev/mapper/loop0p2 /mnt
Onceyou're done, to clean up:
#umount /mnt
#kpartx -d /dev/loop0
#losetup -d /dev/loop0
Mounting a raw p_w_picpath (with LVM)
Ifyour partitions are managed with LVM, use losetup and kpartx as in the previous
exampleto expose the partitions to the host:
#losetup -f
/dev/loop0
#losetup /dev/loop0 rhel62.img
#kpartx -av /dev/loop0
Next,you need to use the vgscan command to identify the LVM volume groups andthen
vgchangeto expose the volumes as devices:
#vgscan
Readingall physical volumes. This may take a while...
Foundvolume group "vg_rhel62x8664" using metadata type lvm2
#vgchange -ay
2logical volume(s) in volume group "vg_rhel62x8664" now active
#mount /dev/vg_rhel62x8664/lv_root /mnt
Cleanup when you're done:
#umount /mnt
#vgchange -an vg_rhel62x8664
#kpartx -d /dev/loop0
#losetup -d /dev/loop0
Mounting a qcow2 p_w_picpath (without LVM)
Youneed the nbd (network block device) kernel module loaded to mount qcow2 p_w_picpaths.
Thiswill load it with support for 16 block devices, which is fine for our purposes.As root:
#modprobe nbd max_part=16
Assumingthe first block device (/dev/nbd0) is not currently in use, we can expose thedisk
partitionsusing the qemu-nbd and partprobe commands. As root:
#qemu-nbd -c /dev/nbd0 p_w_picpath.qcow2
#partprobe /dev/nbd0
ComputeVM Image Guide Sep 6, 2013 current
16
Ifthe p_w_picpath has, say three partitions (/boot, /, /swap), there should be one newdevice
createdper partition:
$ls -l /dev/nbd3*
brw-rw----1 root disk 43, 48 2012-03-05 15:32 /dev/nbd0
brw-rw----1 root disk 43, 49 2012-03-05 15:32 /dev/nbd0p1
brw-rw----1 root disk 43, 50 2012-03-05 15:32 /dev/nbd0p2
brw-rw----1 root disk 43, 51 2012-03-05 15:32 /dev/nbd0p3
Note
Ifthe network block device you selected was already in use, the initial qemunbd
commandwill fail silently, and the /dev/nbd3p{1,2,3} device files will
notbe created.
Ifthe p_w_picpath partitions are not managed with LVM, they can be mounted directly:
#mkdir /mnt/p_w_picpath
#mount /dev/nbd3p2 /mnt
Whenyou're done, clean up:
#umount /mnt
#qemu-nbd -d /dev/g nbd0
Mounting a qcow2 p_w_picpath (with LVM)
Ifthe p_w_picpath partitions are managed with LVM, after you use qemu-nbd and partprobe,
youmust use vgscan and vgchange -ay in order to expose the LVMpartitions as devices
thatcan be mounted:
#modprobe nbd max_part=16
#qemu-nbd -c /dev/nbd0 p_w_picpath.qcow2
#partprobe /dev/nbd0# vgscan
Readingall physical volumes. This may take a while...
Foundvolume group "vg_rhel62x8664" using metadata type lvm2
#vgchange -ay
2logical volume(s) in volume group "vg_rhel62x8664" now active
#mount /dev/vg_rhel62x8664/lv_root /mnt
Whenyou're done, clean up:
#umount /mnt
#vgchange -an vg_rhel62x8664
#qemu-nbd -d /dev/nbd0
转载URL: