mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-25 06:03:36 +03:00
814 lines
21 KiB
C++
814 lines
21 KiB
C++
/* -------------------------------------------------------------------------- */
|
|
/* Copyright 2002-2015, OpenNebula Project (OpenNebula.org), C12G Labs */
|
|
/* */
|
|
/* 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 NEBULA_H_
|
|
#define NEBULA_H_
|
|
|
|
#include "SqlDB.h"
|
|
#include "SystemDB.h"
|
|
|
|
#include "NebulaTemplate.h"
|
|
|
|
#include "VirtualMachinePool.h"
|
|
#include "VirtualNetworkPool.h"
|
|
#include "HostPool.h"
|
|
#include "UserPool.h"
|
|
#include "VMTemplatePool.h"
|
|
#include "GroupPool.h"
|
|
#include "DatastorePool.h"
|
|
#include "ClusterPool.h"
|
|
#include "DocumentPool.h"
|
|
#include "ZonePool.h"
|
|
#include "SecurityGroupPool.h"
|
|
#include "VdcPool.h"
|
|
|
|
#include "VirtualMachineManager.h"
|
|
#include "LifeCycleManager.h"
|
|
#include "InformationManager.h"
|
|
#include "TransferManager.h"
|
|
#include "DispatchManager.h"
|
|
#include "RequestManager.h"
|
|
#include "HookManager.h"
|
|
#include "AuthManager.h"
|
|
#include "AclManager.h"
|
|
#include "ImageManager.h"
|
|
|
|
#include "DefaultQuotas.h"
|
|
|
|
#include "Callbackable.h"
|
|
|
|
|
|
/**
|
|
* This is the main class for the OpenNebula daemon oned. It stores references
|
|
* to the main modules and data pools. It also includes functions to bootstrap
|
|
* the system and start all its components.
|
|
*/
|
|
class Nebula
|
|
{
|
|
public:
|
|
|
|
static Nebula& instance()
|
|
{
|
|
static Nebula nebulad;
|
|
|
|
return nebulad;
|
|
};
|
|
|
|
// --------------------------------------------------------------
|
|
// Pool Accessors
|
|
// --------------------------------------------------------------
|
|
|
|
VirtualMachinePool * get_vmpool()
|
|
{
|
|
return vmpool;
|
|
};
|
|
|
|
HostPool * get_hpool()
|
|
{
|
|
return hpool;
|
|
};
|
|
|
|
VirtualNetworkPool * get_vnpool()
|
|
{
|
|
return vnpool;
|
|
};
|
|
|
|
UserPool * get_upool()
|
|
{
|
|
return upool;
|
|
};
|
|
|
|
ImagePool * get_ipool()
|
|
{
|
|
return ipool;
|
|
};
|
|
|
|
GroupPool * get_gpool()
|
|
{
|
|
return gpool;
|
|
};
|
|
|
|
VMTemplatePool * get_tpool()
|
|
{
|
|
return tpool;
|
|
};
|
|
|
|
DatastorePool * get_dspool()
|
|
{
|
|
return dspool;
|
|
};
|
|
|
|
ClusterPool * get_clpool()
|
|
{
|
|
return clpool;
|
|
};
|
|
|
|
DocumentPool * get_docpool()
|
|
{
|
|
return docpool;
|
|
};
|
|
|
|
ZonePool * get_zonepool()
|
|
{
|
|
return zonepool;
|
|
};
|
|
|
|
SecurityGroupPool * get_secgrouppool()
|
|
{
|
|
return secgrouppool;
|
|
};
|
|
|
|
VdcPool * get_vdcpool()
|
|
{
|
|
return vdcpool;
|
|
};
|
|
|
|
// --------------------------------------------------------------
|
|
// Manager Accessors
|
|
// --------------------------------------------------------------
|
|
|
|
VirtualMachineManager * get_vmm()
|
|
{
|
|
return vmm;
|
|
};
|
|
|
|
LifeCycleManager * get_lcm()
|
|
{
|
|
return lcm;
|
|
};
|
|
|
|
InformationManager * get_im()
|
|
{
|
|
return im;
|
|
};
|
|
|
|
TransferManager * get_tm()
|
|
{
|
|
return tm;
|
|
};
|
|
|
|
DispatchManager * get_dm()
|
|
{
|
|
return dm;
|
|
};
|
|
|
|
HookManager * get_hm()
|
|
{
|
|
return hm;
|
|
};
|
|
|
|
AuthManager * get_authm()
|
|
{
|
|
return authm;
|
|
};
|
|
|
|
ImageManager * get_imagem()
|
|
{
|
|
return imagem;
|
|
};
|
|
|
|
AclManager * get_aclm()
|
|
{
|
|
return aclm;
|
|
};
|
|
|
|
// --------------------------------------------------------------
|
|
// Environment & Configuration
|
|
// --------------------------------------------------------------
|
|
|
|
/**
|
|
* Returns the value of LOG->DEBUG_LEVEL in oned.conf file
|
|
* @return the debug level, to instantiate Log'ers
|
|
*/
|
|
Log::MessageType get_debug_level() const
|
|
{
|
|
Log::MessageType clevel = Log::ERROR;
|
|
vector<const Attribute *> logs;
|
|
int rc;
|
|
int log_level_int;
|
|
|
|
rc = nebula_configuration->get("LOG", logs);
|
|
|
|
if ( rc != 0 )
|
|
{
|
|
string value;
|
|
const VectorAttribute * log = static_cast<const VectorAttribute *>
|
|
(logs[0]);
|
|
value = log->vector_value("DEBUG_LEVEL");
|
|
|
|
log_level_int = atoi(value.c_str());
|
|
|
|
if ( Log::ERROR <= log_level_int && log_level_int <= Log::DDDEBUG )
|
|
{
|
|
clevel = static_cast<Log::MessageType>(log_level_int);
|
|
}
|
|
}
|
|
|
|
return clevel;
|
|
}
|
|
|
|
/**
|
|
* Returns the value of LOG->SYSTEM in oned.conf file
|
|
* @return the logging system CERR, FILE_TS or SYSLOG
|
|
*/
|
|
NebulaLog::LogType get_log_system() const
|
|
{
|
|
vector<const Attribute *> logs;
|
|
int rc;
|
|
NebulaLog::LogType log_system = NebulaLog::UNDEFINED;
|
|
|
|
rc = nebula_configuration->get("LOG", logs);
|
|
|
|
if ( rc != 0 )
|
|
{
|
|
string value;
|
|
const VectorAttribute * log = static_cast<const VectorAttribute *>
|
|
(logs[0]);
|
|
|
|
value = log->vector_value("SYSTEM");
|
|
log_system = NebulaLog::str_to_type(value);
|
|
}
|
|
|
|
return log_system;
|
|
};
|
|
|
|
/**
|
|
* Returns the value of ONE_LOCATION env variable. When this variable is
|
|
* not defined the nebula location is "/".
|
|
* @return the nebula location.
|
|
*/
|
|
const string& get_nebula_location()
|
|
{
|
|
return nebula_location;
|
|
};
|
|
|
|
/**
|
|
* Returns the path where mad executables are stored, if ONE_LOCATION is
|
|
* defined this path points to $ONE_LOCATION/bin, otherwise it is
|
|
* /usr/lib/one/mads.
|
|
* @return the mad execs location.
|
|
*/
|
|
const string& get_mad_location()
|
|
{
|
|
return mad_location;
|
|
};
|
|
|
|
/**
|
|
* Returns the path where defaults for mads are stored, if ONE_LOCATION is
|
|
* defined this path points to $ONE_LOCATION/etc, otherwise it is /etc/one
|
|
* @return the mad defaults location.
|
|
*/
|
|
const string& get_defaults_location()
|
|
{
|
|
return etc_location;
|
|
};
|
|
|
|
/**
|
|
* Returns the path where logs (oned.log, schedd.log,...) are generated
|
|
* if ONE_LOCATION is defined this path points to $ONE_LOCATION/var,
|
|
* otherwise it is /var/log/one.
|
|
* @return the log location.
|
|
*/
|
|
const string& get_log_location()
|
|
{
|
|
return log_location;
|
|
};
|
|
|
|
/**
|
|
* Returns the default var location. When ONE_LOCATION is defined this path
|
|
* points to $ONE_LOCATION/var, otherwise it is /var/lib/one.
|
|
* @return the log location.
|
|
*/
|
|
const string& get_var_location()
|
|
{
|
|
return var_location;
|
|
};
|
|
|
|
/**
|
|
*
|
|
*
|
|
*/
|
|
int get_ds_location(int cluster_id, string& dsloc)
|
|
{
|
|
if ( cluster_id != -1 )
|
|
{
|
|
Cluster * cluster = clpool->get(cluster_id, true);
|
|
|
|
if ( cluster == 0 )
|
|
{
|
|
return -1;
|
|
}
|
|
|
|
cluster->get_ds_location(dsloc);
|
|
|
|
cluster->unlock();
|
|
}
|
|
else
|
|
{
|
|
get_configuration_attribute("DATASTORE_LOCATION", dsloc);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* Returns the default vms location. When ONE_LOCATION is defined this path
|
|
* points to $ONE_LOCATION/var/vms, otherwise it is /var/lib/one/vms. This
|
|
* location stores vm related files: deployment, transfer, context, and
|
|
* logs (in self-contained mode only)
|
|
* @return the vms location.
|
|
*/
|
|
const string& get_vms_location()
|
|
{
|
|
return vms_location;
|
|
};
|
|
|
|
/**
|
|
* Returns the path of the log file for a VM, depending where OpenNebula is
|
|
* installed,
|
|
* $ONE_LOCATION/var/$VM_ID/vm.log
|
|
* or
|
|
* /var/log/one/$VM_ID.log
|
|
* @return the log location for the VM.
|
|
*/
|
|
string get_vm_log_filename(int oid)
|
|
{
|
|
ostringstream oss;
|
|
|
|
if (nebula_location == "/")
|
|
{
|
|
oss << log_location << oid << ".log";
|
|
}
|
|
else
|
|
{
|
|
oss << vms_location << oid << "/vm.log";
|
|
}
|
|
|
|
return oss.str();
|
|
};
|
|
|
|
/**
|
|
* Returns the name of the host running oned
|
|
* @return the name
|
|
*/
|
|
const string& get_nebula_hostname()
|
|
{
|
|
return hostname;
|
|
};
|
|
|
|
/**
|
|
* Returns the version of oned
|
|
* @return the version
|
|
*/
|
|
static string version()
|
|
{
|
|
return "OpenNebula " + code_version();
|
|
};
|
|
|
|
/**
|
|
* Returns the version of oned
|
|
* @return
|
|
*/
|
|
static string code_version()
|
|
{
|
|
return "4.14.0"; // bump version
|
|
}
|
|
|
|
/**
|
|
* Version needed for the DB, shared tables
|
|
* @return
|
|
*/
|
|
static string shared_db_version()
|
|
{
|
|
return "4.11.80";
|
|
}
|
|
|
|
/**
|
|
* Version needed for the DB, local tables
|
|
* @return
|
|
*/
|
|
static string local_db_version()
|
|
{
|
|
return "4.13.85";
|
|
}
|
|
|
|
/**
|
|
* Starts all the modules and services for OpenNebula
|
|
*/
|
|
void start(bool bootstrap_only=false);
|
|
|
|
/**
|
|
* Initialize the database
|
|
*/
|
|
void bootstrap_db();
|
|
|
|
// --------------------------------------------------------------
|
|
// Federation
|
|
// --------------------------------------------------------------
|
|
|
|
bool is_federation_enabled()
|
|
{
|
|
return federation_enabled;
|
|
};
|
|
|
|
bool is_federation_master()
|
|
{
|
|
return federation_master;
|
|
|
|
};
|
|
|
|
bool is_federation_slave()
|
|
{
|
|
return federation_enabled && !federation_master;
|
|
};
|
|
|
|
int get_zone_id()
|
|
{
|
|
return zone_id;
|
|
};
|
|
|
|
const string& get_master_oned()
|
|
{
|
|
return master_oned;
|
|
};
|
|
|
|
// -----------------------------------------------------------------------
|
|
// Configuration attributes (read from oned.conf)
|
|
// -----------------------------------------------------------------------
|
|
|
|
/**
|
|
* Gets a configuration attribute for oned
|
|
* @param name of the attribute
|
|
* @param value of the attribute
|
|
*/
|
|
void get_configuration_attribute(
|
|
const char * name,
|
|
string& value) const
|
|
{
|
|
string _name(name);
|
|
|
|
nebula_configuration->Template::get(_name, value);
|
|
};
|
|
|
|
/**
|
|
* Gets a configuration attribute for oned (long long version)
|
|
*/
|
|
void get_configuration_attribute(
|
|
const char * name,
|
|
long long& value) const
|
|
{
|
|
string _name(name);
|
|
|
|
nebula_configuration->Template::get(_name, value);
|
|
};
|
|
|
|
/**
|
|
* Gets a configuration attribute for oned (time_t version)
|
|
*/
|
|
void get_configuration_attribute(
|
|
const char * name,
|
|
time_t& value) const
|
|
{
|
|
nebula_configuration->get(name, value);
|
|
};
|
|
|
|
/**
|
|
* Gets a configuration attribute for oned, bool version
|
|
*/
|
|
void get_configuration_attribute(
|
|
const char * name,
|
|
bool& value) const
|
|
{
|
|
string _name(name);
|
|
|
|
nebula_configuration->Template::get(_name, value);
|
|
};
|
|
|
|
/**
|
|
* Gets a TM configuration attribute
|
|
*/
|
|
int get_tm_conf_attribute(
|
|
const string& tm_name,
|
|
const VectorAttribute* &value) const
|
|
{
|
|
vector<const Attribute*>::const_iterator it;
|
|
vector<const Attribute*> values;
|
|
|
|
nebula_configuration->Template::get("TM_MAD_CONF", values);
|
|
|
|
for (it = values.begin(); it != values.end(); it ++)
|
|
{
|
|
value = dynamic_cast<const VectorAttribute*>(*it);
|
|
|
|
if (value == 0)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if (value->vector_value("NAME") == tm_name)
|
|
{
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
value = 0;
|
|
return -1;
|
|
};
|
|
|
|
|
|
/**
|
|
* Gets an XML document with all of the configuration attributes
|
|
* @return the XML
|
|
*/
|
|
string get_configuration_xml() const
|
|
{
|
|
string xml;
|
|
return nebula_configuration->to_xml(xml);
|
|
};
|
|
|
|
// -----------------------------------------------------------------------
|
|
// Default Quotas
|
|
// -----------------------------------------------------------------------
|
|
|
|
/**
|
|
* Get the default quotas for OpenNebula users
|
|
* @return the default quotas
|
|
*/
|
|
const DefaultQuotas& get_default_user_quota()
|
|
{
|
|
return default_user_quota;
|
|
};
|
|
|
|
/**
|
|
* Set the default quotas for OpenNebula users
|
|
* @param tmpl template with the default quotas
|
|
* @param error describes the error if any
|
|
*
|
|
* @return 0 if success
|
|
*/
|
|
int set_default_user_quota(Template *tmpl, string& error)
|
|
{
|
|
int rc = default_user_quota.set(tmpl, error);
|
|
|
|
if ( rc == 0 )
|
|
{
|
|
rc = default_user_quota.update();
|
|
}
|
|
|
|
return rc;
|
|
};
|
|
|
|
/**
|
|
* Get the default quotas for OpenNebula for groups
|
|
* @return the default quotas
|
|
*/
|
|
const DefaultQuotas& get_default_group_quota()
|
|
{
|
|
return default_group_quota;
|
|
};
|
|
|
|
/**
|
|
* Set the default quotas for OpenNebula groups
|
|
* @param tmpl template with the default quotas
|
|
* @param error describes the error if any
|
|
*
|
|
* @return 0 if success
|
|
*/
|
|
int set_default_group_quota(Template *tmpl, string& error)
|
|
{
|
|
int rc = default_group_quota.set(tmpl, error);
|
|
|
|
if ( rc == 0 )
|
|
{
|
|
rc = default_group_quota.update();
|
|
}
|
|
|
|
return rc;
|
|
};
|
|
|
|
// -----------------------------------------------------------------------
|
|
// System attributes
|
|
// -----------------------------------------------------------------------
|
|
/**
|
|
* Reads a System attribute from the DB
|
|
* @param attr_name name of the attribute
|
|
* @param cb Callback that will receive the attribute in XML
|
|
* @return 0 on success
|
|
*/
|
|
int select_sys_attribute(const string& attr_name, string& attr_xml)
|
|
{
|
|
return system_db->select_sys_attribute(attr_name, attr_xml);
|
|
};
|
|
|
|
/**
|
|
* Writes a system attribute in the database.
|
|
* @param db pointer to the db
|
|
* @return 0 on success
|
|
*/
|
|
int insert_sys_attribute(
|
|
const string& attr_name,
|
|
const string& xml_attr,
|
|
string& error_str)
|
|
{
|
|
return system_db->insert_sys_attribute(attr_name, xml_attr, error_str);
|
|
};
|
|
|
|
/**
|
|
* Updates the system attribute in the database.
|
|
* @param db pointer to the db
|
|
* @return 0 on success
|
|
*/
|
|
int update_sys_attribute(
|
|
const string& attr_name,
|
|
const string& xml_attr,
|
|
string& error_str)
|
|
{
|
|
return system_db->update_sys_attribute(attr_name, xml_attr, error_str);
|
|
};
|
|
|
|
private:
|
|
|
|
// -----------------------------------------------------------------------
|
|
//Constructors and = are private to only access the class through instance
|
|
// -----------------------------------------------------------------------
|
|
|
|
Nebula():nebula_configuration(0),
|
|
default_user_quota( "DEFAULT_USER_QUOTAS",
|
|
"/DEFAULT_USER_QUOTAS/DATASTORE_QUOTA",
|
|
"/DEFAULT_USER_QUOTAS/NETWORK_QUOTA",
|
|
"/DEFAULT_USER_QUOTAS/IMAGE_QUOTA",
|
|
"/DEFAULT_USER_QUOTAS/VM_QUOTA"),
|
|
default_group_quota("DEFAULT_GROUP_QUOTAS",
|
|
"/DEFAULT_GROUP_QUOTAS/DATASTORE_QUOTA",
|
|
"/DEFAULT_GROUP_QUOTAS/NETWORK_QUOTA",
|
|
"/DEFAULT_GROUP_QUOTAS/IMAGE_QUOTA",
|
|
"/DEFAULT_GROUP_QUOTAS/VM_QUOTA"),
|
|
system_db(0), db(0),
|
|
vmpool(0), hpool(0), vnpool(0), upool(0), ipool(0), gpool(0), tpool(0),
|
|
dspool(0), clpool(0), docpool(0), zonepool(0), secgrouppool(0), vdcpool(0),
|
|
lcm(0), vmm(0), im(0), tm(0), dm(0), rm(0), hm(0), authm(0),
|
|
aclm(0), imagem(0)
|
|
{
|
|
const char * nl = getenv("ONE_LOCATION");
|
|
|
|
if (nl == 0) //OpenNebula installed under root directory
|
|
{
|
|
nebula_location = "/";
|
|
|
|
mad_location = "/usr/lib/one/mads/";
|
|
etc_location = "/etc/one/";
|
|
log_location = "/var/log/one/";
|
|
var_location = "/var/lib/one/";
|
|
remotes_location = "/var/lib/one/remotes/";
|
|
vms_location = "/var/lib/one/vms/";
|
|
}
|
|
else
|
|
{
|
|
nebula_location = nl;
|
|
|
|
if ( nebula_location.at(nebula_location.size()-1) != '/' )
|
|
{
|
|
nebula_location += "/";
|
|
}
|
|
|
|
mad_location = nebula_location + "lib/mads/";
|
|
etc_location = nebula_location + "etc/";
|
|
log_location = nebula_location + "var/";
|
|
var_location = nebula_location + "var/";
|
|
remotes_location = nebula_location + "var/remotes/";
|
|
vms_location = nebula_location + "var/vms/";
|
|
}
|
|
};
|
|
|
|
~Nebula()
|
|
{
|
|
delete vmpool;
|
|
delete vnpool;
|
|
delete hpool;
|
|
delete upool;
|
|
delete ipool;
|
|
delete gpool;
|
|
delete tpool;
|
|
delete dspool;
|
|
delete clpool;
|
|
delete docpool;
|
|
delete zonepool;
|
|
delete secgrouppool;
|
|
delete vdcpool;
|
|
delete vmm;
|
|
delete lcm;
|
|
delete im;
|
|
delete tm;
|
|
delete dm;
|
|
delete rm;
|
|
delete hm;
|
|
delete authm;
|
|
delete aclm;
|
|
delete imagem;
|
|
delete nebula_configuration;
|
|
delete db;
|
|
delete system_db;
|
|
};
|
|
|
|
Nebula& operator=(Nebula const&){return *this;};
|
|
|
|
// ---------------------------------------------------------------
|
|
// Environment variables
|
|
// ---------------------------------------------------------------
|
|
|
|
string nebula_location;
|
|
|
|
string mad_location;
|
|
string etc_location;
|
|
string log_location;
|
|
string var_location;
|
|
string hook_location;
|
|
string remotes_location;
|
|
string vms_location;
|
|
|
|
string hostname;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Configuration
|
|
// ---------------------------------------------------------------
|
|
|
|
OpenNebulaTemplate * nebula_configuration;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Federation
|
|
// ---------------------------------------------------------------
|
|
|
|
bool federation_enabled;
|
|
bool federation_master;
|
|
int zone_id;
|
|
string master_oned;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Default quotas
|
|
// ---------------------------------------------------------------
|
|
|
|
DefaultQuotas default_user_quota;
|
|
DefaultQuotas default_group_quota;
|
|
|
|
// ---------------------------------------------------------------
|
|
// The system database
|
|
// ---------------------------------------------------------------
|
|
|
|
SystemDB * system_db;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Nebula Pools
|
|
// ---------------------------------------------------------------
|
|
|
|
SqlDB * db;
|
|
VirtualMachinePool * vmpool;
|
|
HostPool * hpool;
|
|
VirtualNetworkPool * vnpool;
|
|
UserPool * upool;
|
|
ImagePool * ipool;
|
|
GroupPool * gpool;
|
|
VMTemplatePool * tpool;
|
|
DatastorePool * dspool;
|
|
ClusterPool * clpool;
|
|
DocumentPool * docpool;
|
|
ZonePool * zonepool;
|
|
SecurityGroupPool * secgrouppool;
|
|
VdcPool * vdcpool;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Nebula Managers
|
|
// ---------------------------------------------------------------
|
|
|
|
LifeCycleManager * lcm;
|
|
VirtualMachineManager * vmm;
|
|
InformationManager * im;
|
|
TransferManager * tm;
|
|
DispatchManager * dm;
|
|
RequestManager * rm;
|
|
HookManager * hm;
|
|
AuthManager * authm;
|
|
AclManager * aclm;
|
|
ImageManager * imagem;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Implementation functions
|
|
// ---------------------------------------------------------------
|
|
|
|
friend void nebula_signal_handler (int sig);
|
|
};
|
|
|
|
#endif /*NEBULA_H_*/
|