Add ability to use LVM volumes for VM disks. Implements LVM disks support for libvirt driver. VM disks will be stored on LVM volumes in volume group specified by `libvirt_images_volume_group` option. Another option `libvirt_local_images_type` specify which storage type will be used. Supported values are `raw`, `lvm`, `qcow2`, `default`. If `libvirt_local_images_type` = `default`, usual logic with `use_cow_images` flag is used. Boolean option `libvirt_sparse_logical_volumes` controls which type of logical volumes will be created (sparsed with virtualsize or usual logical volumes with full space allocation). Default value for this option is `False`. Commit introduce three classes: `Raw`, `Qcow2` and `Lvm`. They contain image creation logic, that was stored in `LibvirtConnection._cache_image` and `libvirt_info` methods, that produce right `LibvirtGuestConfigDisk` configurations for libvirt. `Backend` class choose which image type to use. Change-Id: I0d01cb7d2fd67de2565b8d45d34f7846ad4112c2
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# vim: tabstop=4 shiftwidth=4 softtabstop=4
 | 
						|
 | 
						|
# Copyright 2012 Grid Dynamics
 | 
						|
# All Rights Reserved.
 | 
						|
#
 | 
						|
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
 | 
						|
#    not use this file except in compliance with the License. You may obtain
 | 
						|
#    a copy of the License at
 | 
						|
#
 | 
						|
#         http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
#
 | 
						|
#    Unless required by applicable law or agreed to in writing, software
 | 
						|
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | 
						|
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 | 
						|
#    License for the specific language governing permissions and limitations
 | 
						|
#    under the License.
 | 
						|
 | 
						|
import os
 | 
						|
 | 
						|
from nova.virt.libvirt import config
 | 
						|
from nova.virt.libvirt import imagebackend
 | 
						|
 | 
						|
 | 
						|
class Backend(object):
 | 
						|
    def __init__(self, use_cow):
 | 
						|
        pass
 | 
						|
 | 
						|
    def image(self, instance, name, suffix='', image_type=''):
 | 
						|
        class FakeImage(imagebackend.Image):
 | 
						|
            def __init__(self, instance, name, suffix=''):
 | 
						|
                self.path = os.path.join(instance, name + suffix)
 | 
						|
 | 
						|
            def create_image(self, prepare_template, base,
 | 
						|
                              size, *args, **kwargs):
 | 
						|
                pass
 | 
						|
 | 
						|
            def cache(self, fn, fname, size=None, *args, **kwargs):
 | 
						|
                pass
 | 
						|
 | 
						|
            def libvirt_info(self, device_type):
 | 
						|
                info = config.LibvirtConfigGuestDisk()
 | 
						|
                info.source_type = 'file'
 | 
						|
                info.source_device = device_type
 | 
						|
                info.driver_format = 'raw'
 | 
						|
                info.source_path = self.path
 | 
						|
                return info
 | 
						|
 | 
						|
        return FakeImage(instance, name, suffix)
 |