mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-11 05:17:41 +03:00
60aff2d402
git-svn-id: http://svn.opennebula.org/one/trunk@330 3034c82b-c49b-4eb3-8279-a7acafdc01c0
372 lines
9.7 KiB
C++
372 lines
9.7 KiB
C++
/* -------------------------------------------------------------------------- */
|
|
/* Copyright 2002-2009, Distributed Systems Architecture Group, Universidad */
|
|
/* Complutense de Madrid (dsa-research.org) */
|
|
/* */
|
|
/* 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 <sqlite3.h>
|
|
|
|
#include "Log.h"
|
|
#include "NebulaTemplate.h"
|
|
|
|
#include "VirtualMachinePool.h"
|
|
#include "VirtualNetworkPool.h"
|
|
#include "HostPool.h"
|
|
|
|
#include "VirtualMachineManager.h"
|
|
#include "LifeCycleManager.h"
|
|
#include "InformationManager.h"
|
|
#include "TransferManager.h"
|
|
#include "DispatchManager.h"
|
|
#include "RequestManager.h"
|
|
|
|
class Nebula
|
|
{
|
|
public:
|
|
|
|
static Nebula& instance()
|
|
{
|
|
static Nebula nebulad;
|
|
|
|
return nebulad;
|
|
};
|
|
|
|
// ---------------------------------------------------------------
|
|
// Logging
|
|
// ---------------------------------------------------------------
|
|
|
|
static void log(
|
|
const char * module,
|
|
const Log::MessageType type,
|
|
const ostringstream& message,
|
|
const char * filename = 0,
|
|
Log::MessageType clevel = Log::ERROR)
|
|
{
|
|
static Log nebula_log(filename,clevel,ios_base::trunc);
|
|
static pthread_mutex_t log_mutex = PTHREAD_MUTEX_INITIALIZER;
|
|
|
|
pthread_mutex_lock(&log_mutex);
|
|
nebula_log.log(module,type,message);
|
|
pthread_mutex_unlock(&log_mutex);
|
|
};
|
|
|
|
static void log(
|
|
const char * module,
|
|
const Log::MessageType type,
|
|
const char * message,
|
|
const char * filename = 0)
|
|
{
|
|
ostringstream os(message);
|
|
|
|
Nebula::log(module,type,os,filename);
|
|
};
|
|
|
|
// --------------------------------------------------------------
|
|
// Pool Accessors
|
|
// --------------------------------------------------------------
|
|
|
|
VirtualMachinePool * get_vmpool()
|
|
{
|
|
return vmpool;
|
|
};
|
|
|
|
HostPool * get_hpool()
|
|
{
|
|
return hpool;
|
|
};
|
|
|
|
VirtualNetworkPool * get_vnpool()
|
|
{
|
|
return vnpool;
|
|
};
|
|
|
|
// --------------------------------------------------------------
|
|
// 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;
|
|
};
|
|
|
|
// --------------------------------------------------------------
|
|
// Environment & Configuration
|
|
// --------------------------------------------------------------
|
|
|
|
/**
|
|
* 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 path where the OpenNebula DB and the VM local directories
|
|
* are stored. 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;
|
|
};
|
|
|
|
/**
|
|
* 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 << nebula_location << "var/" << oid << "/vm.log";
|
|
}
|
|
|
|
return oss.str();
|
|
};
|
|
|
|
const string& get_nebula_hostname()
|
|
{
|
|
return hostname;
|
|
};
|
|
|
|
static string version()
|
|
{
|
|
return "OpenNebula 1.3.0";
|
|
};
|
|
|
|
void start();
|
|
|
|
void get_configuration_attribute(
|
|
const char * name,
|
|
string& value) const
|
|
{
|
|
string _name(name);
|
|
|
|
nebula_configuration->Template::get(_name,value);
|
|
};
|
|
|
|
private:
|
|
|
|
// -----------------------------------------------------------------------
|
|
//Constructors and = are private to only access the class through instance
|
|
// -----------------------------------------------------------------------
|
|
|
|
Nebula():nebula_configuration(0),db(0),vmpool(0),hpool(0),vnpool(0),lcm(0),
|
|
vmm(0),im(0),tm(0),dm(0),rm(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/";
|
|
}
|
|
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/";
|
|
}
|
|
};
|
|
|
|
~Nebula()
|
|
{
|
|
if ( vmpool != 0)
|
|
{
|
|
delete vmpool;
|
|
}
|
|
|
|
if ( vnpool != 0)
|
|
{
|
|
delete vnpool;
|
|
}
|
|
|
|
if ( hpool != 0)
|
|
{
|
|
delete hpool;
|
|
}
|
|
|
|
if ( vmm != 0)
|
|
{
|
|
delete vmm;
|
|
}
|
|
|
|
if ( lcm != 0)
|
|
{
|
|
delete lcm;
|
|
}
|
|
|
|
if ( im != 0)
|
|
{
|
|
delete im;
|
|
}
|
|
|
|
if ( tm != 0)
|
|
{
|
|
delete tm;
|
|
}
|
|
|
|
if ( dm != 0)
|
|
{
|
|
delete dm;
|
|
}
|
|
|
|
if ( rm != 0)
|
|
{
|
|
delete rm;
|
|
}
|
|
|
|
if ( nebula_configuration != 0)
|
|
{
|
|
delete nebula_configuration;
|
|
}
|
|
|
|
if ( db != 0 )
|
|
{
|
|
delete db;
|
|
}
|
|
};
|
|
|
|
Nebula(Nebula const&){};
|
|
|
|
Nebula& operator=(Nebula const&){return *this;};
|
|
|
|
// ---------------------------------------------------------------
|
|
// Environment variables
|
|
// ---------------------------------------------------------------
|
|
|
|
string nebula_location;
|
|
|
|
string mad_location;
|
|
string etc_location;
|
|
string log_location;
|
|
string var_location;
|
|
string hostname;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Configuration
|
|
// ---------------------------------------------------------------
|
|
|
|
NebulaTemplate * nebula_configuration;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Nebula Pools
|
|
// ---------------------------------------------------------------
|
|
|
|
SqliteDB * db;
|
|
VirtualMachinePool * vmpool;
|
|
HostPool * hpool;
|
|
VirtualNetworkPool * vnpool;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Nebula Managers
|
|
// ---------------------------------------------------------------
|
|
|
|
LifeCycleManager * lcm;
|
|
VirtualMachineManager * vmm;
|
|
InformationManager * im;
|
|
TransferManager * tm;
|
|
DispatchManager * dm;
|
|
RequestManager * rm;
|
|
|
|
// ---------------------------------------------------------------
|
|
// Implementation functions
|
|
// ---------------------------------------------------------------
|
|
|
|
friend void nebula_signal_handler (int sig);
|
|
};
|
|
|
|
#endif /*NEBULA_H_*/
|