2008-06-17 16:27:32 +00:00
/* -------------------------------------------------------------------------- */
2013-01-24 16:18:30 +01:00
/* Copyright 2002-2013, OpenNebula Project (OpenNebula.org), C12G Labs */
2008-06-17 16:27:32 +00:00
/* */
/* 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. */
/* -------------------------------------------------------------------------- */
# ifndef VIRTUAL_MACHINE_H_
# define VIRTUAL_MACHINE_H_
# include "VirtualMachineTemplate.h"
# include "PoolSQL.h"
# include "History.h"
2012-12-04 23:19:08 +01:00
# include "Image.h"
2008-06-17 16:27:32 +00:00
# include "Log.h"
2010-05-25 18:19:22 +02:00
# include "NebulaLog.h"
2008-06-17 16:27:32 +00:00
# include <time.h>
2012-06-15 12:28:20 +02:00
# include <set>
2008-06-17 16:27:32 +00:00
# include <sstream>
using namespace std ;
2011-06-01 12:41:46 +02:00
class AuthRequest ;
2008-06-17 16:27:32 +00:00
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
/**
* The Virtual Machine class . It represents a VM . . .
*/
class VirtualMachine : public PoolObjectSQL
{
public :
2008-06-22 01:51:49 +00:00
// -------------------------------------------------------------------------
2010-12-31 17:00:26 +01:00
// VM States
2009-03-06 12:10:15 +00:00
// -------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
/**
* Global Virtual Machine state
*/
enum VmState
{
INIT = 0 ,
PENDING = 1 ,
HOLD = 2 ,
ACTIVE = 3 ,
STOPPED = 4 ,
SUSPENDED = 5 ,
DONE = 6 ,
2012-09-04 18:30:53 +02:00
FAILED = 7 ,
POWEROFF = 8
2008-06-17 16:27:32 +00:00
} ;
/**
2009-03-06 12:10:15 +00:00
* Virtual Machine state associated to the Life - cycle Manager
2008-06-17 16:27:32 +00:00
*/
enum LcmState
{
2012-10-16 14:59:16 +02:00
LCM_INIT = 0 ,
PROLOG = 1 ,
BOOT = 2 ,
RUNNING = 3 ,
MIGRATE = 4 ,
SAVE_STOP = 5 ,
SAVE_SUSPEND = 6 ,
SAVE_MIGRATE = 7 ,
PROLOG_MIGRATE = 8 ,
PROLOG_RESUME = 9 ,
EPILOG_STOP = 10 ,
EPILOG = 11 ,
SHUTDOWN = 12 ,
CANCEL = 13 ,
FAILURE = 14 ,
2013-01-21 12:27:18 +01:00
CLEANUP_RESUBMIT = 15 ,
2012-10-16 14:59:16 +02:00
UNKNOWN = 16 ,
HOTPLUG = 17 ,
SHUTDOWN_POWEROFF = 18 ,
2012-10-16 15:32:06 +02:00
BOOT_UNKNOWN = 19 ,
2012-10-17 12:34:32 +02:00
BOOT_POWEROFF = 20 ,
2012-10-17 15:40:02 +02:00
BOOT_SUSPENDED = 21 ,
2013-01-21 12:27:18 +01:00
BOOT_STOPPED = 22 ,
2013-02-28 02:49:56 +01:00
CLEANUP_DELETE = 23 ,
2013-03-06 18:33:18 +01:00
HOTPLUG_SNAPSHOT = 24 ,
2013-03-07 23:40:01 +01:00
HOTPLUG_NIC = 25 ,
HOTPLUG_SAVEAS = 26 ,
HOTPLUG_SAVEAS_POWEROFF = 27 ,
HOTPLUG_SAVEAS_SUSPENDED = 28
2008-06-17 16:27:32 +00:00
} ;
2008-06-22 01:51:49 +00:00
// -------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
// Log & Print
2009-03-06 12:10:15 +00:00
// -------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
/**
* writes a log message in vm . log . The class lock should be locked and
2009-03-06 12:10:15 +00:00
* the VM MUST BE obtained through the VirtualMachinePool get ( ) method .
2008-06-17 16:27:32 +00:00
*/
void log (
const char * module ,
const Log : : MessageType type ,
const ostringstream & message ) const
{
if ( _log ! = 0 )
{
2010-04-21 00:40:16 +02:00
_log - > log ( module , type , message . str ( ) . c_str ( ) ) ;
2008-06-17 16:27:32 +00:00
}
} ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
/**
* writes a log message in vm . log . The class lock should be locked and
2009-03-06 12:10:15 +00:00
* the VM MUST BE obtained through the VirtualMachinePool get ( ) method .
2008-06-17 16:27:32 +00:00
*/
void log (
const char * module ,
const Log : : MessageType type ,
2009-03-06 12:10:15 +00:00
const char * message ) const
2008-06-17 16:27:32 +00:00
{
if ( _log ! = 0 )
{
_log - > log ( module , type , message ) ;
}
} ;
2009-03-06 12:10:15 +00:00
2010-04-21 00:40:16 +02:00
/**
* Function to print the VirtualMachine object into a string in
* XML format
* @ param xml the resulting XML string
* @ return a reference to the generated string
*/
2012-05-11 19:15:25 +02:00
string & to_xml ( string & xml ) const
{
return to_xml_extended ( xml , 1 ) ;
}
2010-04-10 22:16:47 +02:00
2011-06-25 01:29:44 +02:00
/**
* Function to print the VirtualMachine object into a string in
* XML format , with extended information ( full history records )
* @ param xml the resulting XML string
* @ return a reference to the generated string
*/
2012-05-11 19:15:25 +02:00
string & to_xml_extended ( string & xml ) const
{
return to_xml_extended ( xml , 2 ) ;
}
2011-06-25 01:29:44 +02:00
2011-03-01 17:47:20 +01:00
/**
* Rebuilds the object from an xml formatted string
* @ param xml_str The xml - formatted string
*
* @ return 0 on success , - 1 otherwise
*/
int from_xml ( const string & xml_str ) ;
2008-06-17 16:27:32 +00:00
// ------------------------------------------------------------------------
// Dynamic Info
2009-03-06 12:10:15 +00:00
// ------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
/**
* Updates VM dynamic information ( id ) .
* @ param _deploy_id the VMM driver specific id
*/
void update_info (
const string & _deploy_id )
{
deploy_id = _deploy_id ;
} ;
/**
2013-02-16 02:55:17 +01:00
* Updates VM dynamic information ( usage counters ) , and updates last_poll
2012-05-08 16:18:24 +02:00
* @ param _memory Kilobytes used by the VM ( total )
2008-06-17 16:27:32 +00:00
* @ param _cpu used by the VM ( rate )
* @ param _net_tx transmitted bytes ( total )
2012-12-04 13:35:45 +01:00
* @ param _net_rx received bytes ( total )
2008-06-17 16:27:32 +00:00
*/
void update_info (
const int _memory ,
const int _cpu ,
2012-12-04 13:35:45 +01:00
const long long _net_tx ,
2013-02-16 02:55:17 +01:00
const long long _net_rx ,
const map < string , string > & custom ) ;
2008-06-17 16:27:32 +00:00
/**
* Returns the deployment ID
* @ return the VMM driver specific ID
*/
const string & get_deploy_id ( ) const
{
return deploy_id ;
} ;
/**
* Sets the VM exit time
2012-05-04 17:29:36 +02:00
* @ param _et VM exit time ( when it arrived DONE / FAILED states )
2008-06-17 16:27:32 +00:00
*/
void set_exit_time ( time_t et )
{
etime = et ;
} ;
2012-11-19 00:47:02 +01:00
/**
* Sets the KERNEL OS attribute ( path to the kernel file ) . Used when
* the template is using a FILE Datastore for it
* @ param path to the kernel ( in the remote host )
*/
void set_kernel ( const string & kernel )
{
vector < Attribute * > os_attr ;
VectorAttribute * os ;
int num = obj_template - > get ( " OS " , os_attr ) ;
if ( num = = 0 )
{
return ;
}
os = dynamic_cast < VectorAttribute * > ( os_attr [ 0 ] ) ;
os - > replace ( " KERNEL " , kernel ) ;
} ;
/**
* Sets the INITRD OS attribute ( path to the initrd file ) . Used when
* the template is using a FILE Datastore for it
* @ param path to the initrd ( in the remote host )
*/
void set_initrd ( const string & initrd )
{
vector < Attribute * > os_attr ;
VectorAttribute * os ;
int num = obj_template - > get ( " OS " , os_attr ) ;
if ( num = = 0 )
{
return ;
}
os = dynamic_cast < VectorAttribute * > ( os_attr [ 0 ] ) ;
os - > replace ( " INITRD " , initrd ) ;
} ;
2012-02-25 23:31:44 +01:00
// ------------------------------------------------------------------------
// Access to VM locations
// ------------------------------------------------------------------------
/**
* Returns the remote VM directory . The VM remote dir is in the form :
2012-03-02 00:06:57 +01:00
* $ DATASTORE_LOCATION / $ SYSTEM_DS_ID / $ VM_ID . The remote system_dir stores
2012-02-25 23:31:44 +01:00
* disks for a running VM in the target host .
* @ return the remote system directory for the VM
*/
2012-10-05 13:23:44 +02:00
const string & get_remote_system_dir ( ) const
{
return history - > rsystem_dir ;
}
2012-02-25 23:31:44 +01:00
/**
* Returns the local VM directory . The VM local dir is in the form :
* $ SYSTEM_DS_BASE_PATH / $ VM_ID . Temporary stores VM disks .
* @ return the system directory for the VM
*/
2012-03-02 00:06:57 +01:00
string get_system_dir ( ) const ;
2012-02-25 23:31:44 +01:00
2008-06-17 16:27:32 +00:00
// ------------------------------------------------------------------------
// History
2009-03-06 12:10:15 +00:00
// ------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
/**
2008-06-22 22:38:55 +00:00
* Adds a new history record an writes it in the database .
2008-06-17 16:27:32 +00:00
*/
void add_history (
2011-03-08 17:55:14 +01:00
int hid ,
const string & hostname ,
const string & vmm_mad ,
2012-06-28 15:32:52 +02:00
const string & vnm_mad ,
2012-06-29 16:48:43 +02:00
const string & tm_mad ,
2012-10-05 13:23:44 +02:00
const string & ds_location ,
2012-06-29 16:48:43 +02:00
int ds_id ) ;
2008-06-22 01:51:49 +00:00
/**
* Duplicates the last history record . Only the host related fields are
2008-06-22 22:38:55 +00:00
* affected ( i . e . no counter is copied nor initialized ) .
2008-06-22 01:51:49 +00:00
* @ param reason explaining the new addition .
*/
2008-06-22 22:38:55 +00:00
void cp_history ( ) ;
2008-06-22 01:51:49 +00:00
/**
* Duplicates the previous history record . Only the host related fields are
2008-06-22 22:38:55 +00:00
* affected ( i . e . no counter is copied nor initialized ) .
2008-06-22 01:51:49 +00:00
* @ param reason explaining the new addition .
*/
2008-06-22 22:38:55 +00:00
void cp_previous_history ( ) ;
2008-06-17 16:27:32 +00:00
/**
2008-06-22 01:51:49 +00:00
* Checks if the VM has a valid history record . This function
2008-06-17 16:27:32 +00:00
* MUST be called before using any history related function .
* @ return true if the VM has a record
2009-03-06 12:10:15 +00:00
*/
2008-06-17 16:27:32 +00:00
bool hasHistory ( ) const
{
return ( history ! = 0 ) ;
} ;
2008-06-22 01:51:49 +00:00
/**
* Checks if the VM has a valid previous history record . This function
* MUST be called before using any previous_history related function .
* @ return true if the VM has a previous record
2009-03-06 12:10:15 +00:00
*/
2008-06-22 01:51:49 +00:00
bool hasPreviousHistory ( ) const
{
return ( previous_history ! = 0 ) ;
} ;
2009-07-09 14:34:34 +00:00
2008-06-17 16:27:32 +00:00
/**
* Returns the VMM driver name for the current host . The hasHistory ( )
* function MUST be called before this one .
* @ return the VMM mad name
2009-03-06 12:10:15 +00:00
*/
2008-06-17 16:27:32 +00:00
const string & get_vmm_mad ( ) const
{
return history - > vmm_mad_name ;
} ;
2009-07-09 14:34:34 +00:00
/**
* Returns the VMM driver name for the previous host . The hasPreviousHistory ( )
* function MUST be called before this one .
* @ return the VMM mad name
*/
const string & get_previous_vmm_mad ( ) const
{
return previous_history - > vmm_mad_name ;
} ;
2011-11-10 11:15:58 +01:00
/**
* Returns the VNM driver name for the current host . The hasHistory ( )
* function MUST be called before this one .
2011-11-11 14:55:18 +01:00
* @ return the VNM mad name
2011-11-10 11:15:58 +01:00
*/
2011-11-10 22:53:39 +01:00
const string & get_vnm_mad ( ) const
2011-11-10 11:15:58 +01:00
{
2011-11-10 17:28:32 +01:00
return history - > vnm_mad_name ;
2011-11-10 11:15:58 +01:00
} ;
/**
* Returns the VNM driver name for the previous host . The hasPreviousHistory ( )
* function MUST be called before this one .
2011-11-11 14:55:18 +01:00
* @ return the VNM mad name
2011-11-10 11:15:58 +01:00
*/
2011-11-10 22:53:39 +01:00
const string & get_previous_vnm_mad ( ) const
2011-11-10 11:15:58 +01:00
{
2011-11-10 17:28:32 +01:00
return previous_history - > vnm_mad_name ;
2011-11-10 11:15:58 +01:00
} ;
2012-07-02 18:06:07 +02:00
/**
* Returns the datastore ID of the system DS for the host . The hasHistory ( )
* function MUST be called before this one .
* @ return the ds id
*/
string get_ds_id ( ) const
{
ostringstream oss ;
oss < < history - > ds_id ;
return oss . str ( ) ;
} ;
/**
2012-10-05 13:23:44 +02:00
* Returns the datastore ID of the system DS for the previous host .
2012-07-02 18:06:07 +02:00
* The hasPreviousHistory ( ) function MUST be called before this one .
* @ return the TM mad name
*/
string get_previous_ds_id ( ) const
{
ostringstream oss ;
oss < < previous_history - > ds_id ;
2012-10-05 13:23:44 +02:00
2012-07-02 18:06:07 +02:00
return oss . str ( ) ;
} ;
2012-06-28 15:32:52 +02:00
/**
* Returns the TM driver name for the current host . The hasHistory ( )
* function MUST be called before this one .
* @ return the TM mad name
*/
const string & get_tm_mad ( ) const
{
return history - > tm_mad_name ;
} ;
/**
* Returns the TM driver name for the previous host . The
* hasPreviousHistory ( ) function MUST be called before this one .
* @ return the TM mad name
*/
const string & get_previous_tm_mad ( ) const
{
return previous_history - > tm_mad_name ;
} ;
2008-06-17 16:27:32 +00:00
/**
2009-03-06 12:10:15 +00:00
* Returns the transfer filename . The transfer file is in the form :
2012-10-28 19:19:57 +01:00
* $ ONE_LOCATION / var / vms / $ VM_ID / transfer . $ SEQ
2009-01-02 14:58:51 +00:00
* or , in case that OpenNebula is installed in root
2012-10-28 19:19:57 +01:00
* / var / lib / one / vms / $ VM_ID / transfer . $ SEQ
2008-11-13 16:21:17 +00:00
* The hasHistory ( ) function MUST be called before this one .
* @ return the transfer filename
2009-03-06 12:10:15 +00:00
*/
2008-11-13 16:21:17 +00:00
const string & get_transfer_file ( ) const
2008-06-17 16:27:32 +00:00
{
2008-11-13 16:21:17 +00:00
return history - > transfer_file ;
2008-06-17 16:27:32 +00:00
} ;
/**
2008-11-13 16:21:17 +00:00
* Returns the deployment filename . The deployment file is in the form :
2012-10-28 19:19:57 +01:00
* $ ONE_LOCATION / var / vms / $ VM_ID / deployment . $ SEQ
2009-01-02 14:58:51 +00:00
* or , in case that OpenNebula is installed in root
2012-10-28 19:19:57 +01:00
* / var / lib / one / vms / $ VM_ID / deployment . $ SEQ
2008-11-13 16:21:17 +00:00
* The hasHistory ( ) function MUST be called before this one .
2008-06-17 16:27:32 +00:00
* @ return the deployment filename
2009-03-06 12:10:15 +00:00
*/
2008-11-13 16:21:17 +00:00
const string & get_deployment_file ( ) const
2008-06-17 16:27:32 +00:00
{
2008-11-13 16:21:17 +00:00
return history - > deployment_file ;
2008-06-17 16:27:32 +00:00
} ;
2009-03-06 12:10:15 +00:00
/**
* Returns the context filename . The context file is in the form :
2012-10-28 19:19:57 +01:00
* $ ONE_LOCATION / var / vms / $ VM_ID / context . sh
2009-03-06 12:10:15 +00:00
* or , in case that OpenNebula is installed in root
2012-10-28 19:19:57 +01:00
* / var / lib / one / vms / $ VM_ID / context . sh
2009-03-06 12:10:15 +00:00
* The hasHistory ( ) function MUST be called before this one .
* @ return the deployment filename
*/
const string & get_context_file ( ) const
{
return history - > context_file ;
}
2008-11-13 16:21:17 +00:00
/**
* Returns the remote deployment filename . The file is in the form :
2012-10-28 19:19:57 +01:00
* $ DS_LOCATION / $ SYSTEM_DS / $ VM_ID / deployment . $ SEQ
2008-11-13 16:21:17 +00:00
* The hasHistory ( ) function MUST be called before this one .
* @ return the deployment filename
2009-03-06 12:10:15 +00:00
*/
2008-11-13 16:21:17 +00:00
const string & get_remote_deployment_file ( ) const
{
return history - > rdeployment_file ;
2009-03-06 12:10:15 +00:00
} ;
2008-06-17 16:27:32 +00:00
/**
2009-03-06 12:10:15 +00:00
* Returns the checkpoint filename for the current host . The checkpoint file
* is in the form :
2012-10-28 19:19:57 +01:00
* $ DS_LOCATION / $ SYSTEM_DS / $ VM_ID / checkpoint
2008-11-13 16:21:17 +00:00
* The hasHistory ( ) function MUST be called before this one .
2008-06-17 16:27:32 +00:00
* @ return the checkpoint filename
2009-03-06 12:10:15 +00:00
*/
2008-06-17 16:27:32 +00:00
const string & get_checkpoint_file ( ) const
{
return history - > checkpoint_file ;
} ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
/**
* Returns the hostname for the current host . The hasHistory ( )
* function MUST be called before this one .
* @ return the hostname
2009-03-06 12:10:15 +00:00
*/
2008-06-17 16:27:32 +00:00
const string & get_hostname ( ) const
{
return history - > hostname ;
} ;
2009-03-06 12:10:15 +00:00
2008-06-22 01:51:49 +00:00
/**
* Returns the hostname for the previous host . The hasPreviousHistory ( )
* function MUST be called before this one .
* @ return the hostname
2009-03-06 12:10:15 +00:00
*/
2008-06-22 01:51:49 +00:00
const string & get_previous_hostname ( ) const
{
return previous_history - > hostname ;
} ;
2009-03-06 12:10:15 +00:00
2008-11-13 16:21:17 +00:00
/**
* Returns the reason that originated the VM migration in the previous host
* @ return the migration reason to leave this host
*/
const History : : MigrationReason get_previous_reason ( ) const
{
return previous_history - > reason ;
2009-03-06 12:10:15 +00:00
} ;
2008-06-17 16:27:32 +00:00
/**
* Get host id where the VM is or is going to execute . The hasHistory ( )
* function MUST be called before this one .
*/
int get_hid ( )
{
return history - > hid ;
}
2008-06-22 01:51:49 +00:00
/**
* Get host id where the VM was executing . The hasPreviousHistory ( )
* function MUST be called before this one .
*/
int get_previous_hid ( )
{
return previous_history - > hid ;
}
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
/**
* Sets start time of a VM .
* @ param _stime time when the VM started
*/
void set_stime ( time_t _stime )
{
history - > stime = _stime ;
} ;
2012-05-05 20:57:17 +02:00
/**
2012-10-05 13:23:44 +02:00
* Sets VM info ( with monitoring info ) in the history record
2012-05-05 20:57:17 +02:00
*/
2012-05-08 15:42:24 +02:00
void set_vm_info ( )
{
to_xml_extended ( history - > vm_info , 0 ) ;
} ;
2012-05-05 20:57:17 +02:00
/**
2012-10-05 13:23:44 +02:00
* Sets VM info ( with monitoring info ) in the previous history record
2012-05-05 20:57:17 +02:00
*/
2012-05-08 15:42:24 +02:00
void set_previous_vm_info ( )
{
to_xml_extended ( previous_history - > vm_info , 0 ) ;
} ;
2012-05-05 20:57:17 +02:00
2008-06-17 16:27:32 +00:00
/**
* Sets end time of a VM .
* @ param _etime time when the VM finished
*/
void set_etime ( time_t _etime )
{
history - > etime = _etime ;
} ;
2008-06-22 01:51:49 +00:00
/**
* Sets end time of a VM in the previous Host .
* @ param _etime time when the VM finished
*/
void set_previous_etime ( time_t _etime )
{
previous_history - > etime = _etime ;
} ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
/**
* Sets start time of VM prolog .
* @ param _stime time when the prolog started
*/
void set_prolog_stime ( time_t _stime )
{
history - > prolog_stime = _stime ;
} ;
/**
* Sets end time of VM prolog .
* @ param _etime time when the prolog finished
*/
void set_prolog_etime ( time_t _etime )
{
history - > prolog_etime = _etime ;
} ;
/**
* Sets start time of VM running state .
* @ param _stime time when the running state started
*/
void set_running_stime ( time_t _stime )
{
history - > running_stime = _stime ;
} ;
/**
* Sets end time of VM running state .
* @ param _etime time when the running state finished
*/
void set_running_etime ( time_t _etime )
{
history - > running_etime = _etime ;
} ;
2008-06-22 01:51:49 +00:00
/**
* Sets end time of VM running state in the previous host .
* @ param _etime time when the running state finished
*/
void set_previous_running_etime ( time_t _etime )
{
previous_history - > running_etime = _etime ;
} ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
/**
* Sets start time of VM epilog .
* @ param _stime time when the epilog started
*/
void set_epilog_stime ( time_t _stime )
{
2008-06-22 01:51:49 +00:00
history - > epilog_stime = _stime ;
2008-06-17 16:27:32 +00:00
} ;
/**
* Sets end time of VM epilog .
* @ param _etime time when the epilog finished
*/
void set_epilog_etime ( time_t _etime )
{
2008-06-22 01:51:49 +00:00
history - > epilog_etime = _etime ;
2008-06-17 16:27:32 +00:00
} ;
/**
* Sets the reason that originated the VM migration
* @ param _reason migration reason to leave this host
*/
void set_reason ( History : : MigrationReason _reason )
{
history - > reason = _reason ;
} ;
2009-03-06 12:10:15 +00:00
2008-06-22 22:38:55 +00:00
/**
* Sets the reason that originated the VM migration in the previous host
* @ param _reason migration reason to leave this host
*/
void set_previous_reason ( History : : MigrationReason _reason )
{
previous_history - > reason = _reason ;
2009-03-06 12:10:15 +00:00
} ;
2008-06-17 16:27:32 +00:00
// ------------------------------------------------------------------------
// Template
2009-03-06 12:10:15 +00:00
// ------------------------------------------------------------------------
2009-04-02 10:14:54 +00:00
/**
2010-04-10 22:16:47 +02:00
* Parse a string and substitute variables ( e . g . $ NAME ) using the VM
2009-04-02 10:14:54 +00:00
* template values :
* @ param attribute , the string to be parsed
* @ param parsed , the resulting parsed string
2012-11-23 01:40:05 +01:00
* @ param error description in case of failure
2009-04-02 10:14:54 +00:00
* @ return 0 on success .
2010-04-10 22:16:47 +02:00
*/
2012-11-23 01:40:05 +01:00
int parse_template_attribute ( const string & attribute ,
string & parsed ,
string & error ) ;
2012-10-05 13:23:44 +02:00
2012-11-17 02:46:03 +01:00
/**
* Parse a file string variable ( i . e . $ FILE ) using the FILE_DS datastores .
* It should be used for OS / DS_KERNEL , OS / DS_INITRD , CONTEXT / DS_FILES .
2012-11-18 00:01:43 +01:00
* @ param attribute the string to be parsed
* @ param img_ids ids of the FILE images in the attribute
* @ param error description in case of failure
2012-11-17 02:46:03 +01:00
* @ return 0 on success .
*/
2012-11-23 19:51:45 +01:00
int parse_file_attribute ( string attribute ,
vector < int > & img_ids ,
string & error ) ;
2012-11-17 02:46:03 +01:00
2011-06-01 23:53:09 +02:00
/**
* Factory method for virtual machine templates
*/
2012-03-14 15:48:06 +01:00
Template * get_new_template ( ) const
2011-06-01 23:53:09 +02:00
{
return new VirtualMachineTemplate ;
}
2011-04-08 01:02:55 +02:00
2012-06-06 17:05:11 +02:00
/**
* Returns a copy of the VirtualMachineTemplate
* @ return A copy of the VirtualMachineTemplate
*/
VirtualMachineTemplate * clone_template ( ) const
{
return new VirtualMachineTemplate (
* ( static_cast < VirtualMachineTemplate * > ( obj_template ) ) ) ;
} ;
2013-01-04 00:04:01 +01:00
/**
* This function replaces the * user template * .
* @ param tmpl_str new contents
2013-03-12 15:19:00 +01:00
* @ param keep_restricted If true , the restricted attributes of the
* current template will override the new template
2013-01-04 00:04:01 +01:00
* @ param error string describing the error if any
* @ return 0 on success
*/
2013-03-12 15:19:00 +01:00
int replace_template ( const string & tmpl_str , bool keep_restricted , string & error ) ;
2012-06-06 17:05:11 +02:00
2013-02-26 14:32:31 +01:00
void get_user_template_attribute (
const char * name ,
string & value ) const
{
user_obj_template - > get ( name , value ) ;
}
2008-06-17 16:27:32 +00:00
// ------------------------------------------------------------------------
// States
2009-03-06 12:10:15 +00:00
// ------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
/**
* Returns the VM state ( Dispatch Manager )
* @ return the VM state
*/
VmState get_state ( ) const
{
return state ;
} ;
/**
* Returns the VM state ( life - cycle Manager )
* @ return the VM state
*/
LcmState get_lcm_state ( ) const
{
return lcm_state ;
} ;
/**
* Sets VM state
* @ param s state
*/
void set_state ( VmState s )
{
state = s ;
} ;
/**
* Sets VM LCM state
* @ param s state
*/
void set_state ( LcmState s )
{
lcm_state = s ;
} ;
2009-03-06 12:10:15 +00:00
2012-04-26 19:06:49 +02:00
/**
* Sets the re - scheduling flag
* @ param set or unset the re - schedule flag
*/
void set_resched ( bool do_sched )
{
if ( do_sched = = true )
{
resched = 1 ;
}
else
{
resched = 0 ;
}
} ;
2008-06-17 16:27:32 +00:00
// ------------------------------------------------------------------------
2013-02-23 19:49:06 +01:00
// Timers &
2009-03-06 12:10:15 +00:00
// ------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
/**
* Gets time from last information polling .
* @ return time of last poll ( epoch ) or 0 if never polled
*/
time_t get_last_poll ( ) const
{
return last_poll ;
} ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
/**
* Get the VM physical requirements for the host .
* @ param cpu
* @ param memory
2009-03-06 12:10:15 +00:00
* @ param disk
2008-06-17 16:27:32 +00:00
*/
void get_requirements ( int & cpu , int & memory , int & disk ) ;
2009-03-06 12:10:15 +00:00
2013-02-25 17:01:55 +01:00
/**
* Checks if the resize parameters are valid
* @ param cpu New CPU . 0 means unchanged .
* @ param memory New MEMORY . 0 means unchanged .
* @ param vcpu New VCPU . 0 means unchanged .
* @ param error_str Error reason , if any
*
* @ return 0 on success
*/
int check_resize ( float cpu , int memory , int vcpu , string & error_str ) ;
2013-02-23 19:49:06 +01:00
/**
* Resize the VM capacity
* @ param cpu
* @ param memory
* @ param vcpu
2013-02-25 17:01:55 +01:00
* @ param error_str Error reason , if any
*
* @ return 0 on success
2013-02-23 19:49:06 +01:00
*/
2013-02-25 17:01:55 +01:00
int resize ( float cpu , int memory , int vcpu , string & error_str ) ;
2013-02-23 19:49:06 +01:00
2008-11-13 16:21:17 +00:00
// ------------------------------------------------------------------------
2010-06-25 13:24:54 +02:00
// Network Leases & Disk Images
2008-11-13 16:21:17 +00:00
// ------------------------------------------------------------------------
2008-11-14 19:51:33 +00:00
/**
* Get all network leases for this Virtual Machine
* @ return 0 if success
*/
2011-07-08 20:00:27 +02:00
int get_network_leases ( string & error_str ) ;
2009-03-06 12:10:15 +00:00
2008-11-13 16:21:17 +00:00
/**
* Releases all network leases taken by this Virtual Machine
*/
2009-03-06 15:54:57 +00:00
void release_network_leases ( ) ;
2009-03-06 12:10:15 +00:00
2012-12-12 18:31:27 +01:00
/**
* Releases the network lease taken by this NIC
*
* @ param nic NIC to be released
* @ param vmid Virtual Machine oid
*
* @ return 0 on success , - 1 otherwise
*/
static int release_network_leases ( VectorAttribute const * nic , int vmid ) ;
2010-06-25 13:24:54 +02:00
/**
* Get all disk images for this Virtual Machine
2011-03-22 18:40:03 +01:00
* @ param error_str Returns the error reason , if any
2010-06-25 13:24:54 +02:00
* @ return 0 if success
*/
2010-08-05 19:28:28 +02:00
int get_disk_images ( string & error_str ) ;
2010-06-25 13:24:54 +02:00
/**
* Releases all disk images taken by this Virtual Machine
*/
void release_disk_images ( ) ;
2009-03-06 15:54:57 +00:00
// ------------------------------------------------------------------------
// Context related functions
// ------------------------------------------------------------------------
2009-03-06 12:10:15 +00:00
/**
2009-03-07 00:56:26 +00:00
* Writes the context file for this VM , and gets the paths to be included
* in the context block device ( CBD )
* @ param files space separated list of paths to be included in the CBD
2012-10-16 18:27:16 +02:00
* @ param disk_id CONTEXT / DISK_ID attribute value
* @ return - 1 in case of error , 0 if the VM has no context , 1 on success
2009-03-06 12:10:15 +00:00
*/
2012-10-16 18:27:16 +02:00
int generate_context ( string & files , int & disk_id ) ;
2009-03-06 12:10:15 +00:00
2013-03-07 22:44:18 +01:00
// -------------------------------------------------------------------------
2012-03-05 23:49:18 +01:00
// Datastore related functions
2013-03-07 22:44:18 +01:00
// -------------------------------------------------------------------------
/**
* Gest the associated image to the given disk_id
* @ param disk_id of the VM
* @ param hot is this a save_as hot operation
* @ param err_str describing the error
* @ return - 1 if the image cannot saveas
*/
int get_image_from_disk ( int disk_id , bool hot , string & err_str ) ;
/**
* Sets the corresponding SAVE_AS state .
* @ return 0 if the VM can be saved as
*/
int set_saveas_state ( ) ;
/**
* Clears the SAVE_AS state , moving the VM to the original state .
* @ return 0 if the VM was in a SAVE_AS state
*/
int clear_saveas_state ( ) ;
2010-07-21 18:06:40 +02:00
/**
* Set the SAVE_AS attribute for the " disk_id " th disk .
* @ param disk_id Index of the disk to save
2012-03-05 23:49:18 +01:00
* @ param source to save the disk ( SAVE_AS_SOURCE )
* @ param img_id ID of the image this disk will be saved to ( SAVE_AS ) .
2010-07-21 18:06:40 +02:00
*/
2012-10-05 13:23:44 +02:00
int save_disk ( const string & disk_id ,
2012-03-05 23:49:18 +01:00
const string & source ,
int img_id ) ;
2013-03-07 22:44:18 +01:00
/**
* Set the SAVE_AS attribute for the " disk_id " th disk .
* @ param disk_id Index of the disk to save
* @ param source to save the disk ( SAVE_AS_SOURCE )
* @ param img_id ID of the image this disk will be saved to ( SAVE_AS ) .
*/
int save_disk_hot ( const string & disk_id ,
const string & source ,
int img_id ) ;
2012-03-05 23:49:18 +01:00
/**
* Get the original image id of the disk . It also checks that the disk can
* be saved_as .
* @ param disk_id Index of the disk to save
* @ param error_str describes the error
* @ return - 1 if failure
*/
2013-03-07 22:44:18 +01:00
int get_saveas_disk_hot ( int & disk_id , string & source , int & image_id ) ;
/**
* Cleans the HOTPLUG_SAVEAS = YES attribute from the disks
*/
void clear_saveas_disk_hot ( ) ;
2010-07-21 18:06:40 +02:00
2011-06-01 12:41:46 +02:00
// ------------------------------------------------------------------------
// Authorization related functions
// ------------------------------------------------------------------------
/**
* Sets an authorization request for a VirtualMachine template based on
* the images and networks used
* @ param uid for template owner
* @ param ar the AuthRequest object
* @ param tmpl the virtual machine template
*/
2012-10-05 13:23:44 +02:00
static void set_auth_request ( int uid ,
AuthRequest & ar ,
2011-06-01 12:41:46 +02:00
VirtualMachineTemplate * tmpl ) ;
2012-06-13 18:42:42 +02:00
2013-03-07 22:44:18 +01:00
// -------------------------------------------------------------------------
2012-06-13 18:42:42 +02:00
// Hotplug related functions
2013-03-07 22:44:18 +01:00
// -------------------------------------------------------------------------
2012-06-13 18:42:42 +02:00
/**
2012-06-15 12:28:20 +02:00
* Collects information about VM DISKS
2012-10-16 18:27:16 +02:00
* @ param max_disk_id of the VM
2012-06-15 12:28:20 +02:00
* @ param used_targets by the DISKS of the VM
2012-06-13 18:42:42 +02:00
*/
2012-10-16 18:27:16 +02:00
void get_disk_info ( int & max_disk_id , set < string > & used_targets ) ;
2012-06-13 18:42:42 +02:00
2013-03-07 22:44:18 +01:00
/**
* Get the IMAGE_ID of the image that ' s being saved as hot
* @ param disk_id of the DISK
* @ param image_id id of the image being saved
* @ return IMAGE_ID on success , - 1 otherwise
*/
int get_disk_hot_info ( int & image_id , int & disk_id , string & source ) ;
2012-06-15 12:28:20 +02:00
/**
2012-12-12 18:31:27 +01:00
* Generate a DISK attribute to be attached to the VM .
2012-06-15 12:28:20 +02:00
* @ param tmpl Template containing a single DISK vector attribute .
* @ param used_targets targets in use by current DISKS
2012-10-16 18:27:16 +02:00
* @ param max_disk_id Max DISK / DISK_ID of the VM
2012-06-15 12:28:20 +02:00
* @ param uid of the VM owner
2012-12-12 18:31:27 +01:00
* @ param image_id returns the id of the acquired image
2012-06-15 12:28:20 +02:00
* @ param error_str describes the error
*
2012-12-12 18:31:27 +01:00
* @ return a new VectorAttribute with the DISK ( should be freed if not
2012-06-15 12:28:20 +02:00
* added to the template ) , 0 in case of error ;
*/
static VectorAttribute * set_up_attach_disk (
2012-10-25 01:32:35 +02:00
int vm_id ,
2012-06-15 12:28:20 +02:00
VirtualMachineTemplate * tmpl ,
set < string > & used_targets ,
2012-10-16 18:27:16 +02:00
int max_disk_id ,
2012-06-15 12:28:20 +02:00
int uid ,
int & image_id ,
string & error_str ) ;
2012-06-13 18:42:42 +02:00
/**
* Returns the disk that is waiting for an attachment action
*
* @ return the disk waiting for an attachment action , or 0
*/
VectorAttribute * get_attach_disk ( ) ;
/**
2012-06-13 19:15:33 +02:00
* Cleans the ATTACH = YES attribute from the disks
2012-06-14 13:02:18 +02:00
*/
2012-06-15 12:28:20 +02:00
void clear_attach_disk ( ) ;
2012-06-14 13:02:18 +02:00
/**
2012-06-15 12:28:20 +02:00
* Deletes the DISK that was in the process of being attached
2012-06-14 13:02:18 +02:00
*
2012-06-15 12:28:20 +02:00
* @ return the DISK or 0 if no disk was deleted
2012-06-13 18:42:42 +02:00
*/
2012-06-15 12:28:20 +02:00
VectorAttribute * delete_attach_disk ( ) ;
/**
2012-10-05 13:23:44 +02:00
* Adds a new disk to the virtual machine template . The disk should be
2012-06-15 12:28:20 +02:00
* generated by the build_attach_disk
* @ param new_disk must be allocated in the heap
*/
2012-06-15 16:28:30 +02:00
void set_attach_disk ( VectorAttribute * new_disk )
2012-06-15 12:28:20 +02:00
{
new_disk - > replace ( " ATTACH " , " YES " ) ;
obj_template - > set ( new_disk ) ;
}
2012-06-13 18:42:42 +02:00
2012-06-15 16:28:30 +02:00
/**
* Sets the attach attribute to the given disk
* @ param disk_id of the DISK
* @ return 0 if the disk_id was found - 1 otherwise
*/
int set_attach_disk ( int disk_id ) ;
2012-12-12 18:31:27 +01:00
// ------------------------------------------------------------------------
// NIC Hotplug related functions
// ------------------------------------------------------------------------
2012-06-14 17:45:41 +02:00
/**
2012-12-12 18:31:27 +01:00
* Collects information about VM DISKS
* @ param max_disk_id of the VM
*/
void get_nic_info ( int & max_nic_id ) ;
/**
* Generates a NIC attribute to be attached to the VM .
* @ param tmpl Template containing a single NIC vector attribute .
* @ param max_nic_id Max NIC / NIC_ID of the VM
* @ param uid of the VM owner
* @ param network_id returns the id of the acquired network
* @ param error_str describes the error
2012-06-14 17:45:41 +02:00
*
2012-12-12 18:31:27 +01:00
* @ return a new VectorAttribute with the DISK ( should be freed if not
* added to the template ) , 0 in case of error
2012-06-14 17:45:41 +02:00
*/
2012-12-12 18:31:27 +01:00
static VectorAttribute * set_up_attach_nic (
int vm_id ,
VirtualMachineTemplate * tmpl ,
int max_nic_id ,
int uid ,
int & network_id ,
string & error_str ) ;
2012-06-14 17:45:41 +02:00
/**
2012-12-12 18:31:27 +01:00
* Cleans the ATTACH = YES attribute from the NICs
*/
void clear_attach_nic ( ) ;
/**
* Deletes the NIC that was in the process of being attached
2012-06-14 17:45:41 +02:00
*
2012-12-12 18:31:27 +01:00
* @ return the deleted NIC or 0 if none was deleted
*/
VectorAttribute * delete_attach_nic ( ) ;
/**
* Adds a new NIC to the virtual machine template . The NIC should be
* generated by the build_attach_nic
* @ param new_nic must be allocated in the heap
*/
void set_attach_nic ( VectorAttribute * new_nic )
{
new_nic - > replace ( " ATTACH " , " YES " ) ;
obj_template - > set ( new_nic ) ;
}
/**
* Sets the attach attribute to the given NIC
* @ param nic_id of the NIC
* @ return 0 if the nic_id was found , - 1 otherwise
2012-06-14 17:45:41 +02:00
*/
2012-12-12 18:31:27 +01:00
int set_attach_nic ( int nic_id ) ;
2012-06-14 17:45:41 +02:00
2013-02-19 15:21:33 +01:00
// ------------------------------------------------------------------------
// Snapshot related functions
// ------------------------------------------------------------------------
2013-02-20 16:04:09 +01:00
/**
* Creates a new Snapshot attribute , and sets it to ACTIVE = YES
*
2013-02-20 18:11:58 +01:00
* @ param name for the new Snapshot . If it is empty , the generated name
* will be placed in this param
* @ param snap_id Id of the new snapshot
2013-02-20 16:04:09 +01:00
*
* @ return 0 on success
*/
2013-02-20 18:11:58 +01:00
int new_snapshot ( string & name , int & snap_id ) ;
2013-02-19 15:21:33 +01:00
2013-02-20 16:04:09 +01:00
/**
* Sets the given Snapshot as ACTIVE = YES
*
* @ param snap_id the snapshow ID
*
* @ return 0 on success
*/
int set_active_snapshot ( int snap_id ) ;
2013-02-19 15:21:33 +01:00
/**
* Replaces HYPERVISOR_ID for the active SNAPSHOT
*
* @ param hypervisor_id Id returned by the hypervisor for the newly
* created snapshot
*/
void update_snapshot_id ( string & hypervisor_id ) ;
/**
* Cleans the ACTIVE = YES attribute from the snapshots
*/
void clear_active_snapshot ( ) ;
/**
* Deletes the SNAPSHOT that was in the process of being created
*/
void delete_active_snapshot ( ) ;
2013-02-20 18:51:06 +01:00
/**
* Deletes all SNAPSHOT attributes
2012-06-14 17:45:41 +02:00
*/
2013-02-20 18:51:06 +01:00
void delete_snapshots ( ) ;
2012-06-14 17:45:41 +02:00
2008-06-17 16:27:32 +00:00
private :
// -------------------------------------------------------------------------
// Friends
// -------------------------------------------------------------------------
friend class VirtualMachinePool ;
// *************************************************************************
// Virtual Machine Attributes
// *************************************************************************
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
// -------------------------------------------------------------------------
// VM Scheduling & Managing Information
2009-03-06 12:10:15 +00:00
// -------------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
/**
* Last time ( in epoch ) that the VM was polled to get its status
*/
time_t last_poll ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
// -------------------------------------------------------------------------
// Virtual Machine Description
// -------------------------------------------------------------------------
/**
* The state of the virtual machine .
*/
VmState state ;
/**
* The state of the virtual machine ( in the Life - cycle Manager ) .
*/
LcmState lcm_state ;
2012-04-26 19:06:49 +02:00
/**
* Marks the VM as to be re - scheduled
*/
int resched ;
2008-06-17 16:27:32 +00:00
/**
* Start time , the VM enter the nebula system ( in epoch )
*/
time_t stime ;
/**
* Exit time , the VM leave the nebula system ( in epoch )
*/
time_t etime ;
/**
* Deployment specific identification string , as returned by the VM driver
*/
string deploy_id ;
/**
2012-05-08 16:18:24 +02:00
* Memory in Kilobytes used by the VM
2008-06-17 16:27:32 +00:00
*/
int memory ;
/**
* CPU usage ( percent )
*/
int cpu ;
/**
2012-05-08 16:18:24 +02:00
* Network usage , transmitted bytes
2008-06-17 16:27:32 +00:00
*/
2012-12-04 13:35:45 +01:00
long long net_tx ;
2008-06-17 16:27:32 +00:00
/**
2012-05-08 16:18:24 +02:00
* Network usage , received bytes
2008-06-17 16:27:32 +00:00
*/
2012-12-04 13:35:45 +01:00
long long net_rx ;
2008-06-17 16:27:32 +00:00
/**
2008-06-22 01:51:49 +00:00
* History record , for the current host
2008-06-17 16:27:32 +00:00
*/
History * history ;
2008-06-22 01:51:49 +00:00
/**
* History record , for the previous host
*/
History * previous_history ;
2009-03-06 12:10:15 +00:00
2011-06-25 01:29:44 +02:00
/**
* Complete set of history records for the VM
*/
vector < History * > history_records ;
2008-06-17 16:27:32 +00:00
// -------------------------------------------------------------------------
2012-02-24 23:13:22 +01:00
// Logging & Dirs
2008-06-17 16:27:32 +00:00
// -------------------------------------------------------------------------
/**
* Log class for the virtual machine , it writes log messages in
2010-04-10 22:16:47 +02:00
* $ ONE_LOCATION / var / $ VID / vm . log
2009-01-02 14:58:51 +00:00
* or , in case that OpenNebula is installed in root
2010-04-10 22:16:47 +02:00
* / var / log / one / $ VM_ID . log
2013-01-25 17:32:12 +01:00
* For the syslog . . . TODO
2008-06-17 16:27:32 +00:00
*/
2013-01-25 17:32:12 +01:00
Log * _log ;
2012-02-24 23:13:22 +01:00
2013-01-04 00:04:01 +01:00
/**
* User template to store custom metadata . This template can be updated
*
*/
2013-03-12 15:19:00 +01:00
VirtualMachineTemplate * user_obj_template ;
2013-01-04 00:04:01 +01:00
2008-06-17 16:27:32 +00:00
// *************************************************************************
// DataBase implementation (Private)
// *************************************************************************
/**
* Bootstraps the database table ( s ) associated to the VirtualMachine
2011-10-10 06:14:46 -07:00
* @ return 0 on success
2008-06-17 16:27:32 +00:00
*/
2011-10-10 06:14:46 -07:00
static int bootstrap ( SqlDB * db )
2008-06-17 16:27:32 +00:00
{
2011-10-10 06:14:46 -07:00
int rc ;
2010-04-10 22:16:47 +02:00
ostringstream oss_vm ( VirtualMachine : : db_bootstrap ) ;
2012-05-16 16:09:27 +02:00
ostringstream oss_monit ( VirtualMachine : : monit_db_bootstrap ) ;
2010-04-10 22:16:47 +02:00
ostringstream oss_hist ( History : : db_bootstrap ) ;
2008-06-17 16:27:32 +00:00
2011-10-10 06:14:46 -07:00
rc = db - > exec ( oss_vm ) ;
2012-05-16 16:09:27 +02:00
rc + = db - > exec ( oss_monit ) ;
2011-10-10 06:14:46 -07:00
rc + = db - > exec ( oss_hist ) ;
return rc ;
2008-06-17 16:27:32 +00:00
} ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
/**
2010-04-10 22:16:47 +02:00
* Callback function to unmarshall a VirtualMachine object
* ( VirtualMachine : : select )
2008-06-17 16:27:32 +00:00
* @ param num the number of columns read from the DB
2009-05-22 00:46:52 +00:00
* @ param names the column names
* @ param vaues the column values
2008-06-17 16:27:32 +00:00
* @ return 0 on success
*/
2010-04-10 22:16:47 +02:00
int select_cb ( void * nil , int num , char * * names , char * * values ) ;
2010-06-25 13:24:54 +02:00
2010-04-29 18:11:04 +02:00
/**
2010-06-25 13:24:54 +02:00
* Execute an INSERT or REPLACE Sql query .
2010-04-29 18:11:04 +02:00
* @ param db The SQL DB
2010-06-25 13:24:54 +02:00
* @ param replace Execute an INSERT or a REPLACE
2011-12-19 17:07:32 +01:00
* @ param error_str Returns the error reason , if any
2010-04-29 18:11:04 +02:00
* @ return 0 one success
2011-12-19 17:07:32 +01:00
*/
int insert_replace ( SqlDB * db , bool replace , string & error_str ) ;
2009-07-09 14:34:34 +00:00
2008-06-17 16:27:32 +00:00
/**
* Updates the VM history record
* @ param db pointer to the db
2009-03-06 12:10:15 +00:00
* @ return 0 on success
2008-06-17 16:27:32 +00:00
*/
2010-04-10 22:16:47 +02:00
int update_history ( SqlDB * db )
2008-06-17 16:27:32 +00:00
{
if ( history ! = 0 )
{
2010-05-03 19:29:08 +02:00
return history - > update ( db ) ;
2008-06-17 16:27:32 +00:00
}
else
return - 1 ;
} ;
/**
2008-06-22 01:51:49 +00:00
* Updates the previous history record
2008-06-17 16:27:32 +00:00
* @ param db pointer to the db
2009-03-06 12:10:15 +00:00
* @ return 0 on success
2008-06-17 16:27:32 +00:00
*/
2010-04-10 22:16:47 +02:00
int update_previous_history ( SqlDB * db )
2008-06-22 01:51:49 +00:00
{
if ( previous_history ! = 0 )
{
2010-05-03 19:29:08 +02:00
return previous_history - > update ( db ) ;
2008-06-22 01:51:49 +00:00
}
else
return - 1 ;
} ;
2009-03-06 12:10:15 +00:00
2012-05-16 16:09:27 +02:00
/**
* Inserts the last monitoring , and deletes old monitoring entries .
*
* @ param db pointer to the db
* @ return 0 on success
*/
int update_monitoring ( SqlDB * db ) ;
2009-04-02 10:14:54 +00:00
// -------------------------------------------------------------------------
// Attribute Parser
// -------------------------------------------------------------------------
2009-03-06 12:10:15 +00:00
2009-04-02 10:14:54 +00:00
/**
* Mutex to perform just one attribute parse at a time
*/
static pthread_mutex_t lex_mutex ;
2012-11-18 00:01:43 +01:00
/**
* Generates image attributes ( DS_ID , TM_MAD , SOURCE . . . ) for KERNEL and
* INITRD files .
* @ param os attribute of the VM template
* @ param base_name of the attribute " KERNEL " , or " INITRD "
2012-12-04 23:19:08 +01:00
* @ param base_type of the image attribute KERNEL , RAMDISK
2012-11-18 00:01:43 +01:00
* @ param error_str Returns the error reason , if any
* @ return 0 on success
*/
int set_os_file ( VectorAttribute * os ,
const string & base_name ,
2012-12-04 23:19:08 +01:00
Image : : ImageType base_type ,
2012-11-18 00:01:43 +01:00
string & error_str ) ;
2012-11-17 02:46:03 +01:00
/**
* Parse the " OS " attribute of the template by substituting
* $ FILE variables
* @ param error_str Returns the error reason , if any
* @ return 0 on success
*/
int parse_os ( string & error_str ) ;
2009-04-02 10:14:54 +00:00
/**
2010-03-05 19:17:52 +01:00
* Parse the " CONTEXT " attribute of the template by substituting
* $ VARIABLE , $ VARIABLE [ ATTR ] and $ VARIABLE [ ATTR , ATTR = VALUE ]
2011-03-22 18:40:03 +01:00
* @ param error_str Returns the error reason , if any
2010-03-05 19:17:52 +01:00
* @ return 0 on success
*/
2011-03-22 18:40:03 +01:00
int parse_context ( string & error_str ) ;
2010-03-05 19:17:52 +01:00
/**
2013-02-06 16:34:46 +01:00
* Parse the " SCHED_REQUIREMENTS " attribute of the template by substituting
2010-03-05 19:17:52 +01:00
* $ VARIABLE , $ VARIABLE [ ATTR ] and $ VARIABLE [ ATTR , ATTR = VALUE ]
2011-03-22 18:40:03 +01:00
* @ param error_str Returns the error reason , if any
2010-03-05 19:17:52 +01:00
* @ return 0 on success
*/
2011-03-22 18:40:03 +01:00
int parse_requirements ( string & error_str ) ;
2010-06-25 14:34:44 +02:00
2012-03-05 16:20:04 +01:00
/**
* Adds automatic placement requirements : Datastore and Cluster
*
* @ param error_str Returns the error reason , if any
* @ return 0 on success
*/
int automatic_requirements ( string & error_str ) ;
2010-03-05 19:17:52 +01:00
/**
* Parse the " GRAPHICS " attribute and generates a default PORT if not
* defined
2010-04-10 22:16:47 +02:00
*/
2010-03-05 19:17:52 +01:00
void parse_graphics ( ) ;
2010-04-10 22:16:47 +02:00
2013-02-26 13:03:40 +01:00
/**
* Searches the meaningful attributes and moves them from the user template
* to the internal template
*/
void parse_well_known_attributes ( ) ;
2011-06-25 01:29:44 +02:00
/**
* Function that renders the VM in XML format optinally including
* extended information ( all history records )
* @ param xml the resulting XML string
2012-05-08 15:42:24 +02:00
* @ param n_history Number of history records to include :
* 0 : none
* 1 : the last one
* 2 : all
2011-06-25 01:29:44 +02:00
* @ return a reference to the generated string
*/
2012-05-08 15:42:24 +02:00
string & to_xml_extended ( string & xml , int n_history ) const ;
2011-06-25 01:29:44 +02:00
2008-06-17 16:27:32 +00:00
protected :
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
//**************************************************************************
// Constructor
//**************************************************************************
2009-03-06 12:10:15 +00:00
2012-10-05 13:23:44 +02:00
VirtualMachine ( int id ,
2011-06-30 11:31:00 +02:00
int uid ,
2012-10-05 13:23:44 +02:00
int gid ,
2011-06-30 11:31:00 +02:00
const string & uname ,
const string & gname ,
2013-01-18 18:34:51 +01:00
int umask ,
2011-06-30 11:31:00 +02:00
VirtualMachineTemplate * _vm_template ) ;
2008-06-17 16:27:32 +00:00
virtual ~ VirtualMachine ( ) ;
2009-03-06 12:10:15 +00:00
2008-06-17 16:27:32 +00:00
// *************************************************************************
// DataBase implementation
// *************************************************************************
2012-10-05 13:23:44 +02:00
2012-05-05 03:18:25 +02:00
static const char * table ;
2008-06-17 16:27:32 +00:00
static const char * db_names ;
static const char * db_bootstrap ;
2009-03-06 12:10:15 +00:00
2012-05-16 16:09:27 +02:00
static const char * monit_table ;
static const char * monit_db_names ;
static const char * monit_db_bootstrap ;
2008-06-17 16:27:32 +00:00
/**
* Reads the Virtual Machine ( identified with its OID ) from the database .
* @ param db pointer to the db
* @ return 0 on success
*/
2010-04-10 22:16:47 +02:00
int select ( SqlDB * db ) ;
2008-06-17 16:27:32 +00:00
/**
* Writes the Virtual Machine and its associated template in the database .
* @ param db pointer to the db
* @ return 0 on success
*/
2011-03-08 17:55:14 +01:00
int insert ( SqlDB * db , string & error_str ) ;
2008-06-17 16:27:32 +00:00
/**
* Writes / updates the Virtual Machine data fields in the database .
* @ param db pointer to the db
* @ return 0 on success
*/
2011-03-08 17:55:14 +01:00
int update ( SqlDB * db )
{
2011-12-19 17:07:32 +01:00
string error_str ;
return insert_replace ( db , true , error_str ) ;
2011-03-08 17:55:14 +01:00
}
2010-04-10 22:16:47 +02:00
2008-06-17 16:27:32 +00:00
/**
2010-05-25 18:19:22 +02:00
* Deletes a VM from the database and all its associated information
2008-06-17 16:27:32 +00:00
* @ param db pointer to the db
2010-05-25 18:19:22 +02:00
* @ return - 1
2008-06-17 16:27:32 +00:00
*/
2011-03-08 17:55:14 +01:00
int drop ( SqlDB * db )
2009-03-06 12:10:15 +00:00
{
2010-05-25 18:19:22 +02:00
NebulaLog : : log ( " ONE " , Log : : ERROR , " VM Drop not implemented! " ) ;
return - 1 ;
2008-06-17 16:27:32 +00:00
}
} ;
# endif /*VIRTUAL_MACHINE_H_*/