Use lvs instead of os.listdir in _cleanup_lvm

Compute user may not have permission to list /dev/<VolGroup>
directory. This results in error during instance cleanup and not
deleted lvm images, if libvirt driver use lvm images backend.
To prevent this, _cleanup_lvm use lvs command instead of os.listdir.

This fixes bug 1042710

Change-Id: I82ab4ca5ba3320f50c84e23839fcf6ed8f02be8c
This commit is contained in:
Boris Filippov 2012-09-06 04:00:41 +04:00
parent 06dec8ec1e
commit 08f172bb6c
3 changed files with 17 additions and 1 deletions

View File

@ -185,5 +185,8 @@ lvremove: CommandFilter, /sbin/lvremove, root
# nova/virt/libvirt/utils.py: # nova/virt/libvirt/utils.py:
lvcreate: CommandFilter, /sbin/lvcreate, root lvcreate: CommandFilter, /sbin/lvcreate, root
# nova/virt/libvirt/utils.py:
lvs: CommandFilter, /sbin/lvs, root
# nova/virt/libvirt/utils.py: # nova/virt/libvirt/utils.py:
vgs: CommandFilter, /sbin/vgs, root vgs: CommandFilter, /sbin/vgs, root

View File

@ -565,7 +565,9 @@ class LibvirtDriver(driver.ComputeDriver):
def fullpath(name): def fullpath(name):
return os.path.join(vg, name) return os.path.join(vg, name)
disk_names = filter(belongs_to_instance, os.listdir(vg)) logical_volumes = libvirt_utils.list_logical_volumes(vg)
disk_names = filter(belongs_to_instance, logical_volumes)
disks = map(fullpath, disk_names) disks = map(fullpath, disk_names)
return disks return disks
return [] return []

View File

@ -138,6 +138,17 @@ def volume_group_free_space(vg):
return int(out.strip()) return int(out.strip())
def list_logical_volumes(vg):
"""List logical volumes paths for given volume group.
:param vg: volume group name
"""
out, err = execute('lvs', '--noheadings', '-o', 'lv_path', vg,
run_as_root=True)
return [line.strip() for line in out.splitlines()]
def remove_logical_volumes(*paths): def remove_logical_volumes(*paths):
"""Remove one or more logical volume.""" """Remove one or more logical volume."""
if paths: if paths: