1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-13 13:17:39 +03:00

Bug: Add support for BLOCK disk types. Datastore supports a new attribute DISK_TYPE that is inherited by

the IMAGE and subsequent DISKs in VM templates. By default the FILE type is used
This commit is contained in:
Ruben S. Montero 2012-04-19 11:44:19 +02:00
parent ef459eac2b
commit 62a9ebe555
8 changed files with 123 additions and 31 deletions

View File

@ -21,6 +21,7 @@
#include "ObjectCollection.h" #include "ObjectCollection.h"
#include "DatastoreTemplate.h" #include "DatastoreTemplate.h"
#include "Clusterable.h" #include "Clusterable.h"
#include "Image.h"
/** /**
* The Datastore class. * The Datastore class.
@ -82,6 +83,14 @@ public:
return base_path; return base_path;
}; };
/**
* Retrieves the disk type
* @return disk type
*/
Image::DiskType get_disk_type() const
{
return disk_type;
};
/** /**
* Modifies the given VM disk attribute adding the relevant datastore * Modifies the given VM disk attribute adding the relevant datastore
* attributes * attributes
@ -125,6 +134,11 @@ private:
*/ */
string base_path; string base_path;
/**
* Disk types for the Images created in this datastore
*/
Image::DiskType disk_type;
// ************************************************************************* // *************************************************************************
// Constructor // Constructor
// ************************************************************************* // *************************************************************************

View File

@ -55,6 +55,33 @@ public:
} }
}; };
/**
* Type of Disks (used by the VMM_MAD). Values: BLOCK, CDROM or
* FILE
*/
enum DiskType
{
FILE = 0, /** < File-based disk */
CD_ROM = 1, /** < An ISO9660 disk */
BLOCK = 2 /** < Block-device disk */
};
/**
* Return the string representation of a DiskType
* @param ob the type
* @return the string
*/
static string disk_type_to_str(DiskType ob)
{
switch (ob)
{
case FILE: return "FILE" ; break;
case CD_ROM: return "CDROM" ; break;
case BLOCK: return "BLOCK" ; break;
default: return "";
}
};
/** /**
* Image State * Image State
*/ */
@ -356,6 +383,11 @@ private:
*/ */
ImageType type; ImageType type;
/**
* Type for the Disk
*/
DiskType disk_type;
/** /**
* Persistency of the Image * Persistency of the Image
*/ */

View File

@ -54,6 +54,7 @@ public:
* @param img_template template associated with the image * @param img_template template associated with the image
* @param ds_id the id of the datastore * @param ds_id the id of the datastore
* @param ds_name the name of the datastore * @param ds_name the name of the datastore
* @param ds_type disk type for the image
* @param ds_data the datastore data * @param ds_data the datastore data
* @param oid the id assigned to the Image * @param oid the id assigned to the Image
* @param error_str Returns the error reason, if any * @param error_str Returns the error reason, if any
@ -69,6 +70,7 @@ public:
ImageTemplate * img_template, ImageTemplate * img_template,
int ds_id, int ds_id,
const string& ds_name, const string& ds_name,
Image::DiskType ds_type,
const string& ds_data, const string& ds_data,
int * oid, int * oid,
string& error_str); string& error_str);

View File

@ -96,6 +96,7 @@ int Datastore::insert(SqlDB *db, string& error_str)
{ {
int rc; int rc;
ostringstream oss; ostringstream oss;
string s_disk_type;
Nebula& nd = Nebula::instance(); Nebula& nd = Nebula::instance();
@ -124,6 +125,25 @@ int Datastore::insert(SqlDB *db, string& error_str)
base_path = oss.str(); base_path = oss.str();
get_template_attribute("DISK_TYPE", s_disk_type);
if (s_disk_type == "BLOCK")
{
disk_type = Image::BLOCK;
}
else if (s_disk_type == "CDROM")
{
disk_type = Image::CD_ROM;
}
else
{
disk_type = Image::FILE;
}
if ( tm_mad.empty() == true )
{
goto error_tm;
}
//-------------------------------------------------------------------------- //--------------------------------------------------------------------------
// Insert the Datastore // Insert the Datastore
//-------------------------------------------------------------------------- //--------------------------------------------------------------------------
@ -253,6 +273,7 @@ string& Datastore::to_xml(string& xml) const
"<DS_MAD>" << ds_mad << "</DS_MAD>" << "<DS_MAD>" << ds_mad << "</DS_MAD>" <<
"<TM_MAD>" << tm_mad << "</TM_MAD>" << "<TM_MAD>" << tm_mad << "</TM_MAD>" <<
"<BASE_PATH>" << base_path << "</BASE_PATH>" << "<BASE_PATH>" << base_path << "</BASE_PATH>" <<
"<DISK_TYPE>" << disk_type << "</DISK_TYPE>" <<
"<CLUSTER_ID>" << cluster_id << "</CLUSTER_ID>" << "<CLUSTER_ID>" << cluster_id << "</CLUSTER_ID>" <<
"<CLUSTER>" << cluster << "</CLUSTER>" << "<CLUSTER>" << cluster << "</CLUSTER>" <<
collection_xml << collection_xml <<
@ -270,21 +291,23 @@ string& Datastore::to_xml(string& xml) const
int Datastore::from_xml(const string& xml) int Datastore::from_xml(const string& xml)
{ {
int rc = 0; int rc = 0;
int int_disk_type;
vector<xmlNodePtr> content; vector<xmlNodePtr> content;
// Initialize the internal XML object // Initialize the internal XML object
update_from_str(xml); update_from_str(xml);
// Get class base attributes // Get class base attributes
rc += xpath(oid, "/DATASTORE/ID", -1); rc += xpath(oid, "/DATASTORE/ID", -1);
rc += xpath(uid, "/DATASTORE/UID", -1); rc += xpath(uid, "/DATASTORE/UID", -1);
rc += xpath(gid, "/DATASTORE/GID", -1); rc += xpath(gid, "/DATASTORE/GID", -1);
rc += xpath(uname, "/DATASTORE/UNAME", "not_found"); rc += xpath(uname, "/DATASTORE/UNAME", "not_found");
rc += xpath(gname, "/DATASTORE/GNAME", "not_found"); rc += xpath(gname, "/DATASTORE/GNAME", "not_found");
rc += xpath(name, "/DATASTORE/NAME", "not_found"); rc += xpath(name, "/DATASTORE/NAME", "not_found");
rc += xpath(ds_mad, "/DATASTORE/DS_MAD", "not_found"); rc += xpath(ds_mad, "/DATASTORE/DS_MAD", "not_found");
rc += xpath(tm_mad, "/DATASTORE/TM_MAD", "not_found"); rc += xpath(tm_mad, "/DATASTORE/TM_MAD", "not_found");
rc += xpath(base_path, "/DATASTORE/BASE_PATH", "not_found"); rc += xpath(base_path, "/DATASTORE/BASE_PATH", "not_found");
rc += xpath(int_disk_type,"/DATASTORE/DISK_TYPE", -1);
rc += xpath(cluster_id, "/DATASTORE/CLUSTER_ID", -1); rc += xpath(cluster_id, "/DATASTORE/CLUSTER_ID", -1);
rc += xpath(cluster, "/DATASTORE/CLUSTER", "not_found"); rc += xpath(cluster, "/DATASTORE/CLUSTER", "not_found");
@ -292,6 +315,8 @@ int Datastore::from_xml(const string& xml)
// Permissions // Permissions
rc += perms_from_xml(); rc += perms_from_xml();
disk_type = static_cast<Image::DiskType>(int_disk_type);
// Get associated classes // Get associated classes
ObjectXML::get_nodes("/DATASTORE/IMAGES", content); ObjectXML::get_nodes("/DATASTORE/IMAGES", content);

View File

@ -41,6 +41,7 @@ Image::Image(int _uid,
ImageTemplate * _image_template): ImageTemplate * _image_template):
PoolObjectSQL(-1,IMAGE,"",_uid,_gid,_uname,_gname,table), PoolObjectSQL(-1,IMAGE,"",_uid,_gid,_uname,_gname,table),
type(OS), type(OS),
disk_type(FILE),
regtime(time(0)), regtime(time(0)),
source(""), source(""),
path(""), path(""),
@ -345,6 +346,7 @@ string& Image::to_xml(string& xml) const
"<NAME>" << name << "</NAME>" << "<NAME>" << name << "</NAME>" <<
perms_to_xml(perms_xml) << perms_to_xml(perms_xml) <<
"<TYPE>" << type << "</TYPE>" << "<TYPE>" << type << "</TYPE>" <<
"<DISK_TYPE>" << disk_type << "</DISK_TYPE>" <<
"<PERSISTENT>" << persistent_img << "</PERSISTENT>" << "<PERSISTENT>" << persistent_img << "</PERSISTENT>" <<
"<REGTIME>" << regtime << "</REGTIME>" << "<REGTIME>" << regtime << "</REGTIME>" <<
"<SOURCE>" << source << "</SOURCE>" << "<SOURCE>" << source << "</SOURCE>" <<
@ -371,6 +373,7 @@ int Image::from_xml(const string& xml)
vector<xmlNodePtr> content; vector<xmlNodePtr> content;
int int_state; int int_state;
int int_type; int int_type;
int int_disk_type;
int rc = 0; int rc = 0;
@ -388,6 +391,7 @@ int Image::from_xml(const string& xml)
rc += xpath(name, "/IMAGE/NAME", "not_found"); rc += xpath(name, "/IMAGE/NAME", "not_found");
rc += xpath(int_type, "/IMAGE/TYPE", 0); rc += xpath(int_type, "/IMAGE/TYPE", 0);
rc += xpath(int_disk_type, "/IMAGE/DISK_TYPE", 0);
rc += xpath(persistent_img, "/IMAGE/PERSISTENT", 0); rc += xpath(persistent_img, "/IMAGE/PERSISTENT", 0);
rc += xpath(regtime, "/IMAGE/REGTIME", 0); rc += xpath(regtime, "/IMAGE/REGTIME", 0);
@ -406,8 +410,9 @@ int Image::from_xml(const string& xml)
xpath(path,"/IMAGE/PATH", ""); xpath(path,"/IMAGE/PATH", "");
xpath(fs_type,"/IMAGE/FSTYPE",""); xpath(fs_type,"/IMAGE/FSTYPE","");
type = static_cast<ImageType>(int_type); type = static_cast<ImageType>(int_type);
state = static_cast<ImageState>(int_state); disk_type = static_cast<DiskType>(int_disk_type);
state = static_cast<ImageState>(int_state);
// Get associated classes // Get associated classes
ObjectXML::get_nodes("/IMAGE/TEMPLATE", content); ObjectXML::get_nodes("/IMAGE/TEMPLATE", content);
@ -439,6 +444,7 @@ int Image::disk_attribute( VectorAttribute * disk,
string bus; string bus;
string target; string target;
string driver; string driver;
string disk_attr_type;
ostringstream iid; ostringstream iid;
@ -501,17 +507,20 @@ int Image::disk_attribute( VectorAttribute * disk,
switch(type) switch(type)
{ {
case OS: case OS:
case DATABLOCK: case DATABLOCK: //Type is FILE or BLOCK as inherited from the DS
disk->replace("TYPE","DISK"); disk_attr_type = disk_type_to_str(disk_type);
disk->replace("READONLY","NO"); disk->replace("READONLY","NO");
break; break;
case CDROM: case CDROM: //Always use CDROM type for these ones
disk->replace("TYPE","CDROM"); disk_attr_type = "CDROM"
disk->replace("READONLY","YES"); disk->replace("READONLY","YES");
break; break;
} }
disk->replace("TYPE",disk_attr_type);
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
// TARGET attribute // TARGET attribute
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------

View File

@ -60,16 +60,17 @@ ImagePool::ImagePool(SqlDB * db,
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
int ImagePool::allocate ( int ImagePool::allocate (
int uid, int uid,
int gid, int gid,
const string& uname, const string& uname,
const string& gname, const string& gname,
ImageTemplate* img_template, ImageTemplate* img_template,
int ds_id, int ds_id,
const string& ds_name, const string& ds_name,
const string& ds_data, Image::DiskType disk_type,
int * oid, const string& ds_data,
string& error_str) int * oid,
string& error_str)
{ {
Image * img; Image * img;
Image * img_aux = 0; Image * img_aux = 0;
@ -102,6 +103,8 @@ int ImagePool::allocate (
img->ds_name = ds_name; img->ds_name = ds_name;
img->ds_id = ds_id; img->ds_id = ds_id;
img->disk_type = disk_type;
// --------------------------------------------------------------------- // ---------------------------------------------------------------------
// Insert the Object in the pool & Register the image in the repository // Insert the Object in the pool & Register the image in the repository

View File

@ -313,6 +313,7 @@ void ImageAllocate::request_execute(xmlrpc_c::paramList const& params,
ImageTemplate * tmpl = new ImageTemplate; ImageTemplate * tmpl = new ImageTemplate;
Datastore * ds; Datastore * ds;
Image::DiskType ds_disk_type;
// ------------------------- Parse image template -------------------------- // ------------------------- Parse image template --------------------------
@ -351,7 +352,8 @@ void ImageAllocate::request_execute(xmlrpc_c::paramList const& params,
ds->get_permissions(ds_perms); ds->get_permissions(ds_perms);
ds_name = ds->get_name(); ds_name = ds->get_name();
ds_disk_type = ds->get_disk_type();
ds->to_xml(ds_data); ds->to_xml(ds_data);
@ -387,7 +389,8 @@ void ImageAllocate::request_execute(xmlrpc_c::paramList const& params,
att.gname, att.gname,
tmpl, tmpl,
ds_id, ds_id,
ds_name, ds_name,
ds_disk_type,
ds_data, ds_data,
&id, &id,
error_str); error_str);

View File

@ -417,6 +417,7 @@ void VirtualMachineSaveDisk::request_execute(xmlrpc_c::paramList const& paramLis
Image * img; Image * img;
Datastore * ds; Datastore * ds;
Image::DiskType ds_disk_type;
int rc; int rc;
string error_str; string error_str;
@ -485,6 +486,8 @@ void VirtualMachineSaveDisk::request_execute(xmlrpc_c::paramList const& paramLis
ds->get_permissions(ds_perms); ds->get_permissions(ds_perms);
ds->to_xml(ds_data); ds->to_xml(ds_data);
ds_disk_type = ds->get_disk_type();
ds->unlock(); ds->unlock();
@ -535,10 +538,11 @@ void VirtualMachineSaveDisk::request_execute(xmlrpc_c::paramList const& paramLis
att.uname, att.uname,
att.gname, att.gname,
itemplate, itemplate,
ds_id, ds_id,
ds_name, ds_name,
ds_data, ds_disk_type,
&iid, ds_data,
&iid,
error_str); error_str);
if (rc < 0) if (rc < 0)
{ {