2010-04-27 17:42:37 +02:00
/* ------------------------------------------------------------------------ */
2019-01-16 11:27:59 +01:00
/* Copyright 2002-2019, OpenNebula Project, OpenNebula Systems */
2010-04-27 17:42:37 +02: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. */
/* -------------------------------------------------------------------------*/
2008-06-17 16:27:32 +00:00
# ifndef HOST_H_
# define HOST_H_
# include "PoolSQL.h"
2010-08-04 15:14:53 +02:00
# include "HostTemplate.h"
2008-06-17 16:27:32 +00:00
# include "HostShare.h"
2016-03-15 16:37:36 +01:00
# include "ClusterableSingle.h"
2012-10-25 01:32:35 +02:00
# include "ObjectCollection.h"
# include "NebulaLog.h"
2013-10-04 19:05:55 +02:00
# include "NebulaUtil.h"
2008-06-17 16:27:32 +00:00
using namespace std ;
/**
2010-04-04 01:12:52 +02:00
* The Host class .
2008-06-17 16:27:32 +00:00
*/
2016-03-15 16:37:36 +01:00
class Host : public PoolObjectSQL , public ClusterableSingle
2008-06-17 16:27:32 +00:00
{
public :
2010-04-04 01:12:52 +02:00
2016-04-12 00:33:09 +02:00
// HOST STATES +----------------+
// | VM DEPLOYMENT |
// +----------------+------------+--------+-------+
// | STATE | MONITORING | MANUAL | SCHED |
// +----------------+------------+--------+-------+
// | INIT/MONITORED | Yes | Yes |
// +----------------+------------+--------+-------+
// | DISABLED | Yes | Yes | No |
// +----------------+------------+----------------+
// | OFFLINE | No | No |
// +----------------+-----------------------------+
2008-06-17 16:27:32 +00:00
enum HostState
{
2012-05-18 00:14:18 +02:00
INIT = 0 , /**< Initial state for enabled hosts. */
MONITORING_MONITORED = 1 , /**< Monitoring the host (from monitored). */
2016-04-12 00:33:09 +02:00
MONITORED = 2 , /**< The host has been monitored. */
ERROR = 3 , /**< An error ocurrer in host monitoring. */
DISABLED = 4 , /**< The host is disabled see above. */
2013-04-24 01:12:22 +02:00
MONITORING_ERROR = 5 , /**< Monitoring the host (from error). */
MONITORING_INIT = 6 , /**< Monitoring the host (from init). */
2016-04-12 00:33:09 +02:00
MONITORING_DISABLED = 7 , /**< Monitoring the host (from disabled). */
OFFLINE = 8 /**< The host is set offline, see above */
2008-06-17 16:27:32 +00:00
} ;
2011-02-24 18:12:26 +01:00
/**
* Function to print the Host object into a string in XML format
* @ param xml the resulting XML string
* @ return a reference to the generated string
*/
2011-02-24 23:30:39 +01:00
string & to_xml ( string & xml ) const ;
2009-07-09 14:34:34 +00:00
2008-06-17 16:27:32 +00:00
/**
2011-02-24 18:12:26 +01:00
* Rebuilds the object from an xml formatted string
* @ param xml_str The xml - formatted string
*
* @ return 0 on success , - 1 otherwise
2008-06-17 16:27:32 +00:00
*/
2011-02-24 23:30:39 +01:00
int from_xml ( const string & xml_str ) ;
2008-06-17 16:27:32 +00:00
2013-11-21 11:25:53 +01:00
/**
* Checks if the host is a remote public cloud
* @ return true if the host is a remote public cloud
*/
bool is_public_cloud ( ) const ;
2013-10-04 19:05:55 +02:00
2008-06-17 16:27:32 +00:00
/**
2016-04-12 00:33:09 +02:00
* Sets the current host offline , it will not be monitored nor used by the
* scheduler , manual VM deployment is also restricted
*/
void offline ( ) ;
/**
* Sets the current host disable , it will receive monitor updates , manual
* deployment of VMs is allowed and the scheduler will not consider this
* host .
2010-04-04 01:12:52 +02:00
*/
2013-04-24 01:12:22 +02:00
void disable ( ) ;
2008-06-17 16:27:32 +00:00
/**
2010-04-04 01:12:52 +02:00
* Enables the current host , it will be monitored and could be used by
2008-06-17 16:27:32 +00:00
* the scheduler
2010-04-04 01:12:52 +02:00
*/
2016-04-12 00:33:09 +02:00
void enable ( ) ;
2010-04-04 01:12:52 +02:00
2013-04-24 01:12:22 +02:00
/**
* Sets the host in error
*/
void set_error ( )
{
state = ERROR ;
}
2013-04-25 15:10:12 +02:00
/**
* Updates the Host ' s last_monitored time stamp .
* @ param success if the monitored action was successfully performed
*/
2013-11-18 21:57:02 +01:00
void touch ( bool success )
{
last_monitored = time ( 0 ) ;
switch ( state )
{
2016-04-12 00:33:09 +02:00
case OFFLINE :
state = OFFLINE ;
break ;
2013-11-18 21:57:02 +01:00
case DISABLED :
case MONITORING_DISABLED :
state = DISABLED ;
break ;
case INIT :
case ERROR :
case MONITORED :
case MONITORING_ERROR :
case MONITORING_INIT :
case MONITORING_MONITORED :
if ( success = = true )
{
state = MONITORED ;
}
else
{
state = ERROR ;
}
break ;
}
} ;
2013-04-25 15:10:12 +02:00
2013-02-16 02:55:17 +01:00
/**
* Update host after a successful monitor . It modifies counters , state
* and template attributes
2008-06-17 16:27:32 +00:00
* @ param parse_str string with values to be parsed
2013-02-16 02:55:17 +01:00
* @ param with_vm_info if monitoring contains VM information
* @ param lost set of VMs that should be in the host and were not found
* @ param found VMs running in the host ( as expected ) and info .
2014-03-04 11:42:44 +01:00
* @ param reserved_cpu from cluster defaults
* @ param reserved_mem from cluster defaults
2008-06-17 16:27:32 +00:00
* @ return 0 on success
* */
2013-10-24 15:29:36 +02:00
int update_info ( Template & tmpl ,
2013-02-16 02:55:17 +01:00
bool & with_vm_info ,
set < int > & lost ,
2013-10-17 17:01:43 +02:00
map < int , string > & found ,
2014-03-04 11:42:44 +01:00
const set < int > & non_shared_ds ,
2016-11-05 21:14:38 +01:00
const string & reserved_cpu ,
const string & reserved_mem ) ;
2013-10-21 15:39:58 +02:00
/**
* Extracts the DS attributes from the given template
* @ param parse_str string with values to be parsed
* @ param ds map of DS monitoring information
2013-10-24 15:29:36 +02:00
* @ param template object parsed from parse_str
2013-10-21 15:39:58 +02:00
*
* @ return 0 on success
*/
2013-10-24 15:29:36 +02:00
int extract_ds_info (
2013-10-21 15:39:58 +02:00
string & parse_str ,
2013-10-24 15:29:36 +02:00
Template & tmpl ,
map < int , const VectorAttribute * > & ds ) ;
2013-02-16 02:55:17 +01:00
2013-03-19 19:08:48 +01:00
/**
2013-02-16 02:55:17 +01:00
* Update host after a failed monitor . It state
* and template attributes
* @ param message from the driver
* @ param vm_ids running on the host
*/
void error_info ( const string & message , set < int > & vm_ids ) ;
2008-06-17 16:27:32 +00:00
2012-05-16 18:00:31 +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 ) ;
2008-06-17 16:27:32 +00:00
/**
2013-02-12 17:15:28 +01:00
* Retrieves host state
2010-04-27 17:42:37 +02:00
* @ return HostState code number
2008-06-17 16:27:32 +00:00
*/
HostState get_state ( ) const
{
return state ;
} ;
/**
2013-02-12 17:15:28 +01:00
* Retrieves VMM mad name
2010-04-27 17:42:37 +02:00
* @ return string vmm mad name
2008-06-17 16:27:32 +00:00
*/
const string & get_vmm_mad ( ) const
{
return vmm_mad_name ;
} ;
2010-04-04 01:12:52 +02:00
2008-06-17 16:27:32 +00:00
/**
2013-02-12 17:15:28 +01:00
* Retrieves IM mad name
2010-04-27 17:42:37 +02:00
* @ return string im mad name
2008-06-17 16:27:32 +00:00
*/
const string & get_im_mad ( ) const
{
return im_mad_name ;
} ;
2010-04-04 01:12:52 +02:00
2012-05-18 00:14:18 +02:00
/**
* Sets the corresponding monitoring state based on the actual host state
*/
void set_monitoring_state ( )
{
2013-04-25 16:00:03 +02:00
last_monitored = time ( 0 ) ; //Needed to expire this monitor action
2013-04-24 01:12:22 +02:00
switch ( state )
2012-05-18 00:14:18 +02:00
{
2013-04-24 01:12:22 +02:00
case ERROR :
state = MONITORING_ERROR ;
break ;
case MONITORED :
state = MONITORING_MONITORED ;
break ;
case INIT :
state = MONITORING_INIT ;
break ;
case DISABLED :
state = MONITORING_DISABLED ;
break ;
default :
break ;
2012-05-18 00:14:18 +02:00
}
} ;
2008-06-17 16:27:32 +00:00
/**
2013-02-12 17:15:28 +01:00
* Retrieves last time the host was monitored
2010-04-27 17:42:37 +02:00
* @ return time_t last monitored time
2008-06-17 16:27:32 +00:00
*/
time_t get_last_monitored ( ) const
{
return last_monitored ;
} ;
2014-03-04 11:42:44 +01:00
/**
* Get the reserved capacity for this host . Parameters will be only updated
* if values are defined in the host . Reserved capacity will be subtracted
* from the Host total capacity .
* @ param cpu reserved cpu ( in percentage )
* @ param mem reserved mem ( in KB )
*/
2016-11-05 21:14:38 +01:00
void get_reserved_capacity ( string & cpu , string & mem )
2014-03-04 11:42:44 +01:00
{
2016-11-05 21:14:38 +01:00
get_template_attribute ( " RESERVED_CPU " , cpu ) ;
get_template_attribute ( " RESERVED_MEM " , mem ) ;
2014-03-04 11:42:44 +01:00
}
// -------------------------------------------------------------------------
2016-11-05 21:14:38 +01:00
// Share functions.
2014-03-04 11:42:44 +01:00
// -------------------------------------------------------------------------
2009-07-14 16:40:33 +00:00
2016-11-05 21:14:38 +01:00
long long get_share_running_vms ( )
2009-07-14 16:40:33 +00:00
{
2016-11-05 21:14:38 +01:00
return host_share . get_running_vms ( ) ;
2009-07-14 16:40:33 +00:00
}
2008-06-17 16:27:32 +00:00
/**
2013-02-12 17:15:28 +01:00
* Adds a new VM to the given share by incrementing the cpu , mem and disk
2008-06-17 16:27:32 +00:00
* counters
2012-10-25 01:32:35 +02:00
* @ param vm_id id of the vm to add to the host
2008-06-17 16:27:32 +00:00
* @ param cpu needed by the VM ( percentage )
2012-07-12 12:48:27 +02:00
* @ param mem needed by the VM ( in KB )
2008-06-17 16:27:32 +00:00
* @ param disk needed by the VM
2015-08-21 12:00:19 +02:00
* @ param pci devices needed by th VM
2008-06-17 16:27:32 +00:00
* @ return 0 on success
*/
2015-08-21 01:08:28 +02:00
void add_capacity ( int vm_id , long long cpu , long long mem , long long disk ,
2016-02-04 13:10:42 +01:00
vector < VectorAttribute * > pci )
2008-06-17 16:27:32 +00:00
{
2016-03-01 23:31:31 +01:00
if ( vm_collection . add ( vm_id ) = = 0 )
2012-10-25 01:32:35 +02:00
{
2015-08-21 01:08:28 +02:00
host_share . add ( vm_id , cpu , mem , disk , pci ) ;
2012-10-25 01:32:35 +02:00
}
else
{
ostringstream oss ;
oss < < " Trying to add VM " < < vm_id
< < " , that it is already associated to host " < < oid < < " . " ;
NebulaLog : : log ( " ONE " , Log : : ERROR , oss ) ;
}
2008-06-17 16:27:32 +00:00
} ;
2010-04-04 01:12:52 +02:00
2008-06-17 16:27:32 +00:00
/**
2010-04-04 01:12:52 +02:00
* Deletes a new VM from the given share by decrementing the cpu , mem and
2008-06-17 16:27:32 +00:00
* disk counters
2012-10-25 01:32:35 +02:00
* @ param vm_id id of the vm to delete from the host
* @ param cpu used by the VM ( percentage )
2013-02-12 17:15:28 +01:00
* @ param mem used by the VM ( in KB )
2008-06-17 16:27:32 +00:00
* @ param disk used by the VM
2015-08-21 12:00:19 +02:00
* @ param pci devices needed by th VM
2008-06-17 16:27:32 +00:00
* @ return 0 on success
*/
2015-08-21 12:00:19 +02:00
void del_capacity ( int vm_id , long long cpu , long long mem , long long disk ,
2017-05-26 17:49:07 +02:00
const vector < VectorAttribute * > & pci )
2010-04-04 01:12:52 +02:00
{
2016-03-01 23:31:31 +01:00
if ( vm_collection . del ( vm_id ) = = 0 )
2012-10-25 01:32:35 +02:00
{
2015-08-21 12:00:19 +02:00
host_share . del ( cpu , mem , disk , pci ) ;
2012-10-25 01:32:35 +02:00
}
else
{
ostringstream oss ;
oss < < " Trying to remove VM " < < vm_id
< < " , that it is not associated to host " < < oid < < " . " ;
NebulaLog : : log ( " ONE " , Log : : ERROR , oss ) ;
}
2008-06-17 16:27:32 +00:00
} ;
2013-02-23 19:49:06 +01:00
/**
* Updates the capacity used in a host when a VM is resized
* counters
* @ param cpu increment of cpu requested by the VM
* @ param mem increment of memory requested by the VM
* @ param disk not used
* @ return 0 on success
*/
2017-10-13 12:43:34 +02:00
void update_capacity ( int cpu , long int mem , int disk )
2013-02-23 19:49:06 +01:00
{
host_share . update ( cpu , mem , disk ) ;
} ;
2008-06-17 16:27:32 +00:00
/**
* Tests whether a new VM can be hosted by the host or not
* @ param cpu needed by the VM ( percentage )
* @ param mem needed by the VM ( in Kb )
* @ param disk needed by the VM
2015-08-26 12:34:27 +02:00
* @ param pci devices needed by the VM
* @ param error Returns the error reason , if any
2008-06-17 16:27:32 +00:00
* @ return true if the share can host the VM
*/
2015-08-26 12:34:27 +02:00
bool test_capacity ( long long cpu , long long mem , long long disk ,
2016-02-04 13:10:42 +01:00
vector < VectorAttribute * > & pci , string & error ) const
2008-06-17 16:27:32 +00:00
{
2015-08-26 12:34:27 +02:00
return host_share . test ( cpu , mem , disk , pci , error ) ;
2008-06-17 16:27:32 +00:00
}
2010-04-04 01:12:52 +02:00
2015-09-04 13:22:11 +02:00
/**
* Tests whether a new VM can be hosted by the host or not , checking the
* PCI devices only .
* @ param pci devices needed by the VM
* @ param error Returns the error reason , if any
* @ return true if the share can host the VM
*/
2016-02-04 13:10:42 +01:00
bool test_capacity ( vector < VectorAttribute * > & pci , string & error ) const
2015-09-04 13:22:11 +02:00
{
return host_share . test ( pci , error ) ;
}
2013-09-02 12:53:54 +02:00
/**
* Returns a copy of the VM IDs set
*/
set < int > get_vm_ids ( )
{
2016-03-01 23:31:31 +01:00
return vm_collection . clone ( ) ;
2013-09-02 12:53:54 +02:00
}
2011-06-01 23:53:09 +02:00
/**
* Factory method for host templates
*/
2012-03-14 15:48:06 +01:00
Template * get_new_template ( ) const
2011-06-01 23:53:09 +02:00
{
return new HostTemplate ;
}
2014-11-17 23:17:22 +01:00
/**
* Executed after an update operation to process the new template
* - encrypt VCENTER_PASSWORD attribute .
*/
int post_update_template ( string & error ) ;
2015-05-05 12:14:35 +02:00
/**
* Returns the rediscovered VMs ( from poff to running ) in the previous
* monitorization cycle
* @ return the previous rediscovered VMs ( from poff to running )
*/
const set < int > & get_prev_rediscovered_vms ( ) const
{
2017-06-22 23:37:08 +02:00
return * prev_rediscovered_vms ;
2015-05-05 12:14:35 +02:00
}
/**
* Sets the previous rediscovered VMs ( from poff to running ) . This set
* is not stored in the DB , the pool update method is not needed
* @ param rediscovered_vms the previous rediscovered VMs ( from poff to running )
*/
void set_prev_rediscovered_vms ( const set < int > & rediscovered_vms )
{
2017-06-22 23:37:08 +02:00
* prev_rediscovered_vms = rediscovered_vms ;
2015-05-05 12:14:35 +02:00
}
2008-06-17 16:27:32 +00:00
private :
2010-04-04 01:12:52 +02:00
2008-06-17 16:27:32 +00:00
// -------------------------------------------------------------------------
// Friends
// -------------------------------------------------------------------------
2010-04-04 01:12:52 +02:00
friend class HostPool ;
2008-06-17 16:27:32 +00:00
// -------------------------------------------------------------------------
// Host Description
// -------------------------------------------------------------------------
/**
* The state of the Host
*/
HostState state ;
2010-04-04 01:12:52 +02:00
2015-07-01 15:15:40 -04:00
/**
2008-06-17 16:27:32 +00:00
* Name of the IM driver used to monitor this host
2010-04-04 01:12:52 +02:00
*/
2015-07-01 15:15:40 -04:00
string im_mad_name ;
2010-04-04 01:12:52 +02:00
2015-07-01 15:15:40 -04:00
/**
2008-06-17 16:27:32 +00:00
* Name of the VM driver used to execute VMs in this host
2010-04-04 01:12:52 +02:00
*/
2015-07-01 15:15:40 -04:00
string vmm_mad_name ;
2010-04-04 01:12:52 +02:00
2015-07-01 15:15:40 -04:00
/**
2012-05-18 00:14:18 +02:00
* If Host State = MONITORED last time it got fully monitored or 1 Jan 1970
* Host State = MONITORING * last time it got a signal to be monitored
2010-04-04 01:12:52 +02:00
*/
2009-07-09 14:34:34 +00:00
time_t last_monitored ;
2008-06-17 16:27:32 +00:00
// -------------------------------------------------------------------------
// Host Attributes
// -------------------------------------------------------------------------
/**
2009-07-09 14:34:34 +00:00
* The Share represents the logical capacity associated with the host
2008-06-17 16:27:32 +00:00
*/
2017-06-22 23:37:08 +02:00
HostShare host_share ;
2008-06-17 16:27:32 +00:00
2013-11-06 12:57:57 +01:00
/**
* Tmp set of lost VM IDs . Used to give lost VMs one grace cycle , in case
* they reappear .
*/
2017-06-22 23:37:08 +02:00
set < int > * tmp_lost_vms ;
2013-11-06 12:57:57 +01:00
/**
* Tmp set of zombie VM IDs . Used to give zombie VMs one grace cycle , in
* case they are cleaned .
*/
2017-06-22 23:37:08 +02:00
set < int > * tmp_zombie_vms ;
2013-11-06 12:57:57 +01:00
2015-05-05 12:14:35 +02:00
/**
* Set that stores the VMs reported as found from the poweroff state . This
* is managed from outside the host to avoid deadlocks , as the current
* VM state is needed
*/
2017-06-22 23:37:08 +02:00
set < int > * prev_rediscovered_vms ;
2015-05-05 12:14:35 +02:00
2012-10-25 01:32:35 +02:00
// -------------------------------------------------------------------------
// VM Collection
// -------------------------------------------------------------------------
/**
* Stores a collection with the VMs running in the host
*/
ObjectCollection vm_collection ;
2013-10-04 19:05:55 +02:00
2008-06-17 16:27:32 +00:00
// *************************************************************************
// Constructor
// *************************************************************************
2012-02-24 18:53:18 +01:00
Host ( int id ,
const string & hostname ,
const string & im_mad_name ,
const string & vmm_mad_name ,
2016-03-15 16:37:36 +01:00
int cluster_id ,
const string & cluster_name ) ;
2008-06-17 16:27:32 +00:00
virtual ~ Host ( ) ;
2010-04-04 01:12:52 +02:00
2008-06-17 16:27:32 +00:00
// *************************************************************************
2011-02-24 23:30:39 +01:00
// DataBase implementation (Private)
2008-06-17 16:27:32 +00:00
// *************************************************************************
2010-04-04 01:12:52 +02:00
2008-06-17 16:27:32 +00:00
static const char * db_names ;
static const char * db_bootstrap ;
2010-04-04 01:12:52 +02:00
2008-06-17 16:27:32 +00:00
static const char * table ;
2012-05-16 18:00:31 +02:00
static const char * monit_db_names ;
static const char * monit_db_bootstrap ;
static const char * monit_table ;
2008-06-17 16:27:32 +00:00
/**
2011-02-24 23:30:39 +01:00
* Execute an INSERT or REPLACE Sql query .
* @ param db The SQL DB
* @ 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
2011-02-24 23:30:39 +01:00
* @ return 0 one success
2011-12-19 17:07:32 +01:00
*/
int insert_replace ( SqlDB * db , bool replace , string & error_str ) ;
2008-06-17 16:27:32 +00:00
/**
2011-02-24 23:30:39 +01:00
* Bootstraps the database table ( s ) associated to the Host
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 )
2011-02-24 23:30:39 +01:00
{
2012-05-16 18:00:31 +02:00
int rc ;
2011-02-24 23:30:39 +01:00
ostringstream oss_host ( Host : : db_bootstrap ) ;
2012-05-16 18:00:31 +02:00
ostringstream oss_monit ( Host : : monit_db_bootstrap ) ;
2017-04-21 19:16:45 +02:00
rc = db - > exec_local_wr ( oss_host ) ;
rc + = db - > exec_local_wr ( oss_monit ) ;
2008-06-17 16:27:32 +00:00
2012-05-16 18:00:31 +02:00
return rc ;
2011-02-24 23:30:39 +01:00
} ;
2010-04-04 01:12:52 +02:00
2008-06-17 16:27:32 +00:00
/**
* Writes the Host and its associated HostShares in the database .
* @ param db pointer to the db
* @ return 0 on success
*/
2011-12-19 17:07:32 +01:00
int insert ( SqlDB * db , string & error_str )
{
return insert_replace ( db , false , error_str ) ;
} ;
2009-07-09 14:34:34 +00:00
/**
2008-06-17 16:27:32 +00:00
* Writes / updates the Hosts data fields in the database .
* @ param db pointer to the db
2009-07-09 14:34:34 +00:00
* @ return 0 on success
*/
2011-12-19 17:07:32 +01:00
int update ( SqlDB * db )
{
string error_str ;
return insert_replace ( db , true , error_str ) ;
} ;
2008-06-17 16:27:32 +00:00
} ;
# endif /*HOST_H_*/