mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-05 09:17:41 +03:00
feautre #4403: Adds OFFLINE mode to Host.
This commit is contained in:
parent
a9f8dbd13d
commit
f6c9924629
@ -34,20 +34,29 @@ class Host : public PoolObjectSQL, public ClusterableSingle
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
// HOST STATES +----------------+
|
||||||
// Host States
|
// | VM DEPLOYMENT |
|
||||||
// ----------------------------------------------------------------------
|
// +----------------+------------+--------+-------+
|
||||||
|
// | STATE | MONITORING | MANUAL | SCHED |
|
||||||
|
// +----------------+------------+--------+-------+
|
||||||
|
// | INIT/MONITORED | Yes | Yes |
|
||||||
|
// +----------------+------------+--------+-------+
|
||||||
|
// | DISABLED | Yes | Yes | No |
|
||||||
|
// +----------------+------------+----------------+
|
||||||
|
// | OFFLINE | No | No |
|
||||||
|
// +----------------+-----------------------------+
|
||||||
|
|
||||||
enum HostState
|
enum HostState
|
||||||
{
|
{
|
||||||
INIT = 0, /**< Initial state for enabled hosts. */
|
INIT = 0, /**< Initial state for enabled hosts. */
|
||||||
MONITORING_MONITORED = 1, /**< Monitoring the host (from monitored). */
|
MONITORING_MONITORED = 1, /**< Monitoring the host (from monitored). */
|
||||||
MONITORED = 2, /**< The host has been successfully monitored. */
|
MONITORED = 2, /**< The host has been monitored. */
|
||||||
ERROR = 3, /**< An error ocurrer while monitoring the host. */
|
ERROR = 3, /**< An error ocurrer in host monitoring. */
|
||||||
DISABLED = 4, /**< The host is disabled won't be monitored. */
|
DISABLED = 4, /**< The host is disabled see above. */
|
||||||
MONITORING_ERROR = 5, /**< Monitoring the host (from error). */
|
MONITORING_ERROR = 5, /**< Monitoring the host (from error). */
|
||||||
MONITORING_INIT = 6, /**< Monitoring the host (from init). */
|
MONITORING_INIT = 6, /**< Monitoring the host (from init). */
|
||||||
MONITORING_DISABLED = 7 /**< Monitoring the host (from disabled). */
|
MONITORING_DISABLED = 7, /**< Monitoring the host (from disabled). */
|
||||||
|
OFFLINE = 8 /**< The host is set offline, see above */
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -65,27 +74,6 @@ public:
|
|||||||
*/
|
*/
|
||||||
int from_xml(const string &xml_str);
|
int from_xml(const string &xml_str);
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if the host is enabled
|
|
||||||
* @return true if the host is enabled
|
|
||||||
*/
|
|
||||||
bool isEnabled() const
|
|
||||||
{
|
|
||||||
return state != DISABLED && state != MONITORING_DISABLED;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if the host is being monitored
|
|
||||||
* @return true if the host is enabled
|
|
||||||
*/
|
|
||||||
bool isMonitoring() const
|
|
||||||
{
|
|
||||||
return ((state == MONITORING_ERROR) ||
|
|
||||||
(state == MONITORING_MONITORED)||
|
|
||||||
(state == MONITORING_INIT)||
|
|
||||||
(state == MONITORING_DISABLED));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if the host is a remote public cloud
|
* Checks if the host is a remote public cloud
|
||||||
* @return true if the host is a remote public cloud
|
* @return true if the host is a remote public cloud
|
||||||
@ -93,8 +81,15 @@ public:
|
|||||||
bool is_public_cloud() const;
|
bool is_public_cloud() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Disables the current host, it will not be monitored nor used by the
|
* Sets the current host offline, it will not be monitored nor used by the
|
||||||
* scheduler
|
* 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.
|
||||||
*/
|
*/
|
||||||
void disable();
|
void disable();
|
||||||
|
|
||||||
@ -102,10 +97,7 @@ public:
|
|||||||
* Enables the current host, it will be monitored and could be used by
|
* Enables the current host, it will be monitored and could be used by
|
||||||
* the scheduler
|
* the scheduler
|
||||||
*/
|
*/
|
||||||
void enable()
|
void enable();
|
||||||
{
|
|
||||||
state = INIT;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the host in error
|
* Sets the host in error
|
||||||
@ -125,6 +117,10 @@ public:
|
|||||||
|
|
||||||
switch (state)
|
switch (state)
|
||||||
{
|
{
|
||||||
|
case OFFLINE:
|
||||||
|
state = OFFLINE;
|
||||||
|
break;
|
||||||
|
|
||||||
case DISABLED:
|
case DISABLED:
|
||||||
case MONITORING_DISABLED:
|
case MONITORING_DISABLED:
|
||||||
state = DISABLED;
|
state = DISABLED;
|
||||||
@ -145,8 +141,6 @@ public:
|
|||||||
state = ERROR;
|
state = ERROR;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -28,6 +28,7 @@ extern "C" void * im_action_loop(void *arg);
|
|||||||
|
|
||||||
class HostPool;
|
class HostPool;
|
||||||
class ClusterPool;
|
class ClusterPool;
|
||||||
|
class Host;
|
||||||
|
|
||||||
class InformationManager : public MadManager, public ActionListener
|
class InformationManager : public MadManager, public ActionListener
|
||||||
{
|
{
|
||||||
@ -56,21 +57,6 @@ public:
|
|||||||
|
|
||||||
~InformationManager(){};
|
~InformationManager(){};
|
||||||
|
|
||||||
enum Actions
|
|
||||||
{
|
|
||||||
STOPMONITOR /** Sent by the RM when a host is deleted **/
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Triggers specific actions to the Information Manager.
|
|
||||||
* @param action the IM action
|
|
||||||
* @param hid Host unique id. This is the argument of the passed to the
|
|
||||||
* invoked action.
|
|
||||||
*/
|
|
||||||
void trigger(
|
|
||||||
Actions action,
|
|
||||||
int vid);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This functions starts the associated listener thread, and creates a
|
* This functions starts the associated listener thread, and creates a
|
||||||
* new thread for the Information Manager. This thread will wait in
|
* new thread for the Information Manager. This thread will wait in
|
||||||
@ -88,10 +74,6 @@ public:
|
|||||||
return im_thread;
|
return im_thread;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
int load_mads(int uid=0);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@ -101,7 +83,35 @@ public:
|
|||||||
am.trigger(ACTION_FINALIZE,0);
|
am.trigger(ACTION_FINALIZE,0);
|
||||||
};
|
};
|
||||||
|
|
||||||
void stop_monitor(int hid);
|
/**
|
||||||
|
* Load the information drivers
|
||||||
|
* @return 0 on success
|
||||||
|
*/
|
||||||
|
int load_mads(int uid=0);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sends a STOPMONITR command to the associated driver and host
|
||||||
|
* @param hid the host id
|
||||||
|
* @param name of the host
|
||||||
|
* @param im_mad the driver name
|
||||||
|
*/
|
||||||
|
void stop_monitor(int hid, const string& name, const string& im_mad)
|
||||||
|
{
|
||||||
|
const InformationManagerDriver * imd = get(im_mad);
|
||||||
|
|
||||||
|
if (imd != 0)
|
||||||
|
{
|
||||||
|
imd->stop_monitor(hid, name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Starts the monitor process on the host
|
||||||
|
* @param host to monitor
|
||||||
|
* @param update_remotes to copy the monitor probes to the host
|
||||||
|
* @return 0 on success
|
||||||
|
*/
|
||||||
|
int start_monitor(Host * host, bool update_remotes);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/**
|
/**
|
||||||
|
@ -29,9 +29,9 @@ using namespace std;
|
|||||||
class RequestManagerHost: public Request
|
class RequestManagerHost: public Request
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
RequestManagerHost( const string& method_name,
|
RequestManagerHost(const string& method_name,
|
||||||
const string& help,
|
const string& help,
|
||||||
const string& params)
|
const string& params)
|
||||||
:Request(method_name,params,help)
|
:Request(method_name,params,help)
|
||||||
{
|
{
|
||||||
Nebula& nd = Nebula::instance();
|
Nebula& nd = Nebula::instance();
|
||||||
@ -51,18 +51,23 @@ protected:
|
|||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
/* ------------------------------------------------------------------------- */
|
/* ------------------------------------------------------------------------- */
|
||||||
|
|
||||||
class HostEnable : public RequestManagerHost
|
class HostStatus : public RequestManagerHost
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
HostEnable():
|
enum Status
|
||||||
RequestManagerHost("HostEnable",
|
{
|
||||||
"Enables or disables a host",
|
ENABLED = 0,
|
||||||
"A:sib")
|
DISABLED = 1,
|
||||||
|
OFFLINE = 2
|
||||||
|
};
|
||||||
|
|
||||||
|
HostStatus():
|
||||||
|
RequestManagerHost("HostStatus", "Sets the status of the host", "A:sii")
|
||||||
{
|
{
|
||||||
auth_op = AuthRequest::ADMIN;
|
auth_op = AuthRequest::ADMIN;
|
||||||
};
|
};
|
||||||
|
|
||||||
~HostEnable(){};
|
~HostStatus(){};
|
||||||
|
|
||||||
void request_execute(xmlrpc_c::paramList const& _paramList,
|
void request_execute(xmlrpc_c::paramList const& _paramList,
|
||||||
RequestAttributes& att);
|
RequestAttributes& att);
|
||||||
|
@ -131,7 +131,7 @@ cmd=CommandParser::CmdParser.new(ARGV) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
enable_desc = <<-EOT.unindent
|
enable_desc = <<-EOT.unindent
|
||||||
Enables the given Host
|
Enables the given host, fully operational
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
command :enable, enable_desc, [:range,:hostid_list] do
|
command :enable, enable_desc, [:range,:hostid_list] do
|
||||||
@ -141,7 +141,10 @@ cmd=CommandParser::CmdParser.new(ARGV) do
|
|||||||
end
|
end
|
||||||
|
|
||||||
disable_desc = <<-EOT.unindent
|
disable_desc = <<-EOT.unindent
|
||||||
Disables the given Host
|
Disables the given host:
|
||||||
|
- monitor: enabled
|
||||||
|
- scheduler deployment: disabled
|
||||||
|
- manual deployment: enabled
|
||||||
EOT
|
EOT
|
||||||
|
|
||||||
command :disable, disable_desc, [:range,:hostid_list] do
|
command :disable, disable_desc, [:range,:hostid_list] do
|
||||||
@ -150,6 +153,19 @@ cmd=CommandParser::CmdParser.new(ARGV) do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
offline_desc = <<-EOT.unindent
|
||||||
|
Sets the host offline:
|
||||||
|
- monitor: disabled
|
||||||
|
- scheduler deployment: disabled
|
||||||
|
- manual deployment: disabled
|
||||||
|
EOT
|
||||||
|
|
||||||
|
command :offline, offline_desc, [:range,:hostid_list] do
|
||||||
|
helper.perform_actions(args[0],options,"offline") do |host|
|
||||||
|
host.offline
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
update_desc = <<-EOT.unindent
|
update_desc = <<-EOT.unindent
|
||||||
Update the template contents. If a path is not provided the editor will
|
Update the template contents. If a path is not provided the editor will
|
||||||
be launched to modify the current content.
|
be launched to modify the current content.
|
||||||
|
@ -261,6 +261,11 @@ int Host::update_info(Template &tmpl,
|
|||||||
int num_zombies = 0;
|
int num_zombies = 0;
|
||||||
int num_wilds = 0;
|
int num_wilds = 0;
|
||||||
|
|
||||||
|
if ( state == OFFLINE )
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
// Remove expired information from current template
|
// Remove expired information from current template
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
@ -285,31 +290,28 @@ int Host::update_info(Template &tmpl,
|
|||||||
|
|
||||||
touch(true);
|
touch(true);
|
||||||
|
|
||||||
if (isEnabled())
|
get_reserved_capacity(reserved_cpu, reserved_mem);
|
||||||
{
|
|
||||||
get_reserved_capacity(reserved_cpu, reserved_mem);
|
|
||||||
|
|
||||||
erase_template_attribute("TOTALCPU", val);
|
erase_template_attribute("TOTALCPU", val);
|
||||||
host_share.max_cpu = val - reserved_cpu;
|
host_share.max_cpu = val - reserved_cpu;
|
||||||
erase_template_attribute("TOTALMEMORY", val);
|
erase_template_attribute("TOTALMEMORY", val);
|
||||||
host_share.max_mem = val - reserved_mem;
|
host_share.max_mem = val - reserved_mem;
|
||||||
erase_template_attribute("DS_LOCATION_TOTAL_MB", val);
|
erase_template_attribute("DS_LOCATION_TOTAL_MB", val);
|
||||||
host_share.max_disk = val;
|
host_share.max_disk = val;
|
||||||
|
|
||||||
erase_template_attribute("FREECPU", val);
|
erase_template_attribute("FREECPU", val);
|
||||||
host_share.free_cpu = val;
|
host_share.free_cpu = val;
|
||||||
erase_template_attribute("FREEMEMORY", val);
|
erase_template_attribute("FREEMEMORY", val);
|
||||||
host_share.free_mem = val;
|
host_share.free_mem = val;
|
||||||
erase_template_attribute("DS_LOCATION_FREE_MB", val);
|
erase_template_attribute("DS_LOCATION_FREE_MB", val);
|
||||||
host_share.free_disk = val;
|
host_share.free_disk = val;
|
||||||
|
|
||||||
erase_template_attribute("USEDCPU", val);
|
erase_template_attribute("USEDCPU", val);
|
||||||
host_share.used_cpu = val;
|
host_share.used_cpu = val;
|
||||||
erase_template_attribute("USEDMEMORY", val);
|
erase_template_attribute("USEDMEMORY", val);
|
||||||
host_share.used_mem = val;
|
host_share.used_mem = val;
|
||||||
erase_template_attribute("DS_LOCATION_USED_MB", val);
|
erase_template_attribute("DS_LOCATION_USED_MB", val);
|
||||||
host_share.used_disk = val;
|
host_share.used_disk = val;
|
||||||
}
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
// Correlate VM information with the list of running VMs
|
// Correlate VM information with the list of running VMs
|
||||||
@ -461,9 +463,35 @@ int Host::update_info(Template &tmpl,
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void Host::enable()
|
||||||
|
{
|
||||||
|
if (state == OFFLINE)
|
||||||
|
{
|
||||||
|
Nebula::instance().get_im()->start_monitor(this, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
state = INIT;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
void Host::disable()
|
void Host::disable()
|
||||||
{
|
{
|
||||||
|
if (state == OFFLINE)
|
||||||
|
{
|
||||||
|
Nebula::instance().get_im()->start_monitor(this, true);
|
||||||
|
}
|
||||||
|
|
||||||
state = DISABLED;
|
state = DISABLED;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void Host::offline()
|
||||||
|
{
|
||||||
|
Nebula::instance().get_im()->stop_monitor(get_oid(),get_name(),get_im_mad());
|
||||||
|
|
||||||
|
state = OFFLINE;
|
||||||
|
|
||||||
host_share.max_cpu = 0;
|
host_share.max_cpu = 0;
|
||||||
host_share.max_mem = 0;
|
host_share.max_mem = 0;
|
||||||
@ -583,14 +611,14 @@ string& Host::to_xml(string& xml) const
|
|||||||
|
|
||||||
oss <<
|
oss <<
|
||||||
"<HOST>"
|
"<HOST>"
|
||||||
"<ID>" << oid << "</ID>" <<
|
"<ID>" << oid << "</ID>" <<
|
||||||
"<NAME>" << name << "</NAME>" <<
|
"<NAME>" << name << "</NAME>" <<
|
||||||
"<STATE>" << state << "</STATE>" <<
|
"<STATE>" << state << "</STATE>" <<
|
||||||
"<IM_MAD>" << one_util::escape_xml(im_mad_name) << "</IM_MAD>" <<
|
"<IM_MAD>" << one_util::escape_xml(im_mad_name) << "</IM_MAD>" <<
|
||||||
"<VM_MAD>" << one_util::escape_xml(vmm_mad_name) << "</VM_MAD>" <<
|
"<VM_MAD>" << one_util::escape_xml(vmm_mad_name) << "</VM_MAD>" <<
|
||||||
"<LAST_MON_TIME>" << last_monitored << "</LAST_MON_TIME>" <<
|
"<LAST_MON_TIME>" << last_monitored << "</LAST_MON_TIME>" <<
|
||||||
"<CLUSTER_ID>" << cluster_id << "</CLUSTER_ID>" <<
|
"<CLUSTER_ID>" << cluster_id << "</CLUSTER_ID>" <<
|
||||||
"<CLUSTER>" << cluster << "</CLUSTER>" <<
|
"<CLUSTER>" << cluster << "</CLUSTER>" <<
|
||||||
host_share.to_xml(share_xml) <<
|
host_share.to_xml(share_xml) <<
|
||||||
vm_collection.to_xml(vm_collection_xml) <<
|
vm_collection.to_xml(vm_collection_xml) <<
|
||||||
obj_template->to_xml(template_xml) <<
|
obj_template->to_xml(template_xml) <<
|
||||||
|
@ -119,30 +119,6 @@ int InformationManager::start()
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
void InformationManager::trigger(Actions action, int _hid)
|
|
||||||
{
|
|
||||||
int * hid;
|
|
||||||
string aname;
|
|
||||||
|
|
||||||
hid = new int(_hid);
|
|
||||||
|
|
||||||
switch (action)
|
|
||||||
{
|
|
||||||
case STOPMONITOR:
|
|
||||||
aname = "STOPMONITOR";
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
delete hid;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
am.trigger(aname,hid);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* -------------------------------------------------------------------------- */
|
|
||||||
/* -------------------------------------------------------------------------- */
|
|
||||||
|
|
||||||
void InformationManager::do_action(const string &action, void * arg)
|
void InformationManager::do_action(const string &action, void * arg)
|
||||||
{
|
{
|
||||||
if (action == ACTION_TIMER)
|
if (action == ACTION_TIMER)
|
||||||
@ -155,13 +131,6 @@ void InformationManager::do_action(const string &action, void * arg)
|
|||||||
|
|
||||||
MadManager::stop();
|
MadManager::stop();
|
||||||
}
|
}
|
||||||
else if (action == "STOPMONITOR")
|
|
||||||
{
|
|
||||||
int hid = *(static_cast<int *>(arg));
|
|
||||||
delete static_cast<int *>(arg);
|
|
||||||
|
|
||||||
stop_monitor(hid);
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ostringstream oss;
|
ostringstream oss;
|
||||||
@ -174,68 +143,37 @@ void InformationManager::do_action(const string &action, void * arg)
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
void InformationManager::stop_monitor(int hid)
|
int InformationManager::start_monitor(Host * host, bool update_remotes)
|
||||||
{
|
{
|
||||||
string error_msg;
|
ostringstream oss;
|
||||||
int rc;
|
string dsloc;
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
const InformationManagerDriver * imd;
|
||||||
// Drop host from DB
|
|
||||||
// -------------------------------------------------------------------------
|
|
||||||
Host * host = hpool->get(hid,true);
|
|
||||||
|
|
||||||
if (host == 0) //Already deleted silently return
|
oss << "Monitoring host "<< host->get_name()<< " ("<< host->get_oid()<< ")";
|
||||||
|
NebulaLog::log("InM",Log::DEBUG,oss);
|
||||||
|
|
||||||
|
imd = get(host->get_im_mad());
|
||||||
|
|
||||||
|
if (imd == 0)
|
||||||
{
|
{
|
||||||
return;
|
oss.str("");
|
||||||
|
|
||||||
|
oss << "Could not find information driver " << host->get_im_mad();
|
||||||
|
NebulaLog::log("InM",Log::ERROR,oss);
|
||||||
|
|
||||||
|
host->set_error();
|
||||||
|
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int cluster_id = host->get_cluster_id();
|
host->set_monitoring_state();
|
||||||
string im_mad = host->get_im_mad();
|
|
||||||
|
|
||||||
rc = hpool->drop(host, error_msg);
|
Nebula::instance().get_ds_location(dsloc);
|
||||||
|
|
||||||
host->unlock();
|
imd->monitor(host->get_oid(), host->get_name(), dsloc, update_remotes);
|
||||||
|
|
||||||
if (rc != 0) //Error (a VM has been allocated or DB error)
|
return 0;
|
||||||
{
|
|
||||||
ostringstream oss;
|
|
||||||
|
|
||||||
oss << "Could not delete host " << hid << ": " << error_msg;
|
|
||||||
|
|
||||||
NebulaLog::log("InM", Log::ERROR, oss);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
|
||||||
// Send STOPMONITOR to the IM driver if defined
|
|
||||||
// -------------------------------------------------------------------------
|
|
||||||
const InformationManagerDriver * imd = get(im_mad);
|
|
||||||
|
|
||||||
if (imd != 0)
|
|
||||||
{
|
|
||||||
imd->stop_monitor(hid, host->get_name());
|
|
||||||
}
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
|
||||||
// Remove host from cluster
|
|
||||||
// -------------------------------------------------------------------------
|
|
||||||
Cluster * cluster = clpool->get(cluster_id, true);
|
|
||||||
|
|
||||||
if( cluster != 0 )
|
|
||||||
{
|
|
||||||
rc = cluster->del_host(hid, error_msg);
|
|
||||||
|
|
||||||
if ( rc < 0 )
|
|
||||||
{
|
|
||||||
cluster->unlock();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
clpool->update(cluster);
|
|
||||||
|
|
||||||
cluster->unlock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
@ -245,23 +183,18 @@ void InformationManager::timer_action()
|
|||||||
{
|
{
|
||||||
static int mark = 0;
|
static int mark = 0;
|
||||||
|
|
||||||
int rc;
|
int rc;
|
||||||
time_t now;
|
time_t now;
|
||||||
ostringstream oss;
|
|
||||||
|
|
||||||
set<int> discovered_hosts;
|
set<int> discovered_hosts;
|
||||||
set<int>::iterator it;
|
set<int>::iterator it;
|
||||||
|
|
||||||
const InformationManagerDriver * imd;
|
|
||||||
|
|
||||||
Host * host;
|
Host * host;
|
||||||
istringstream iss;
|
|
||||||
|
|
||||||
time_t monitor_length;
|
time_t monitor_length;
|
||||||
time_t target_time;
|
time_t target_time;
|
||||||
|
|
||||||
bool do_monitor;
|
|
||||||
|
|
||||||
mark = mark + timer_period;
|
mark = mark + timer_period;
|
||||||
|
|
||||||
if ( mark >= 600 )
|
if ( mark >= 600 )
|
||||||
@ -270,7 +203,6 @@ void InformationManager::timer_action()
|
|||||||
mark = 0;
|
mark = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear the expired monitoring records
|
|
||||||
hpool->clean_expired_monitoring();
|
hpool->clean_expired_monitoring();
|
||||||
|
|
||||||
now = time(0);
|
now = time(0);
|
||||||
@ -284,7 +216,7 @@ void InformationManager::timer_action()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for(it=discovered_hosts.begin();it!=discovered_hosts.end();it++)
|
for( it=discovered_hosts.begin() ; it!=discovered_hosts.end() ; ++it )
|
||||||
{
|
{
|
||||||
host = hpool->get(*it,true);
|
host = hpool->get(*it,true);
|
||||||
|
|
||||||
@ -295,106 +227,38 @@ void InformationManager::timer_action()
|
|||||||
|
|
||||||
monitor_length = now - host->get_last_monitored();
|
monitor_length = now - host->get_last_monitored();
|
||||||
|
|
||||||
/**
|
switch (host->get_state())
|
||||||
* Monitor hosts that are:
|
|
||||||
* - enabled and have been being monitored for more than monitor_expire
|
|
||||||
* - enabled and not being monitored
|
|
||||||
* - disabled and not being monitored but have running vms
|
|
||||||
* - disabled with running vms and have been being monitored
|
|
||||||
* for more than monitor_expire secs.
|
|
||||||
*/
|
|
||||||
|
|
||||||
do_monitor = false;
|
|
||||||
|
|
||||||
if (host->isEnabled())
|
|
||||||
{
|
{
|
||||||
if (!host->isMonitoring())
|
// Not received an update in the monitor period.
|
||||||
{
|
case Host::INIT:
|
||||||
do_monitor = true;
|
case Host::MONITORED:
|
||||||
}
|
case Host::ERROR:
|
||||||
else if (monitor_length >= monitor_expire )
|
case Host::DISABLED:
|
||||||
{
|
start_monitor(host, (host->get_last_monitored() == 0));
|
||||||
do_monitor = true;
|
break;
|
||||||
}
|
|
||||||
}
|
|
||||||
else if ( host->get_share_running_vms() > 0 )
|
|
||||||
{
|
|
||||||
if (!host->isMonitoring())
|
|
||||||
{
|
|
||||||
do_monitor = true;
|
|
||||||
}
|
|
||||||
else if (monitor_length >= monitor_expire)
|
|
||||||
{
|
|
||||||
do_monitor = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (do_monitor)
|
// Update last_mon_time to rotate HostPool::discover output. Update
|
||||||
{
|
// monitoring values with 0s.
|
||||||
oss.str("");
|
case Host::OFFLINE:
|
||||||
oss << "Monitoring host " << host->get_name() << " ("
|
host->touch(true);
|
||||||
<< host->get_oid() << ")";
|
hpool->update_monitoring(host);
|
||||||
|
break;
|
||||||
|
|
||||||
NebulaLog::log("InM",Log::DEBUG,oss);
|
// Host is being monitored for more than monitor_expire secs.
|
||||||
|
case Host::MONITORING_DISABLED:
|
||||||
imd = get(host->get_im_mad());
|
case Host::MONITORING_INIT:
|
||||||
|
case Host::MONITORING_ERROR:
|
||||||
if (imd == 0)
|
case Host::MONITORING_MONITORED:
|
||||||
{
|
if (monitor_length >= monitor_expire )
|
||||||
oss.str("");
|
|
||||||
oss << "Could not find information driver " << host->get_im_mad();
|
|
||||||
NebulaLog::log("InM",Log::ERROR,oss);
|
|
||||||
|
|
||||||
host->set_error();
|
|
||||||
|
|
||||||
hpool->update(host);
|
|
||||||
|
|
||||||
host->unlock();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Nebula& nd = Nebula::instance();
|
|
||||||
bool update_remotes = false;
|
|
||||||
|
|
||||||
string name = host->get_name();
|
|
||||||
int oid = host->get_oid();
|
|
||||||
|
|
||||||
string dsloc;
|
|
||||||
|
|
||||||
//Force remotes update if the host has never been monitored.
|
|
||||||
if (host->get_last_monitored() == 0)
|
|
||||||
{
|
{
|
||||||
update_remotes = true;
|
start_monitor(host, (host->get_last_monitored() == 0));
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
host->set_monitoring_state();
|
|
||||||
|
|
||||||
hpool->update(host);
|
|
||||||
|
|
||||||
host->unlock();
|
|
||||||
|
|
||||||
nd.get_ds_location(dsloc);
|
|
||||||
|
|
||||||
imd->monitor(oid, name, dsloc, update_remotes);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (!host->isEnabled() && host->get_share_running_vms() == 0 )
|
|
||||||
{
|
|
||||||
// Disabled hosts without VMs are not monitored, but we need to
|
|
||||||
// update the last_mon_time to rotate the Hosts returned by
|
|
||||||
// HostPool::discover. We also update the monitoring values with
|
|
||||||
// 0s
|
|
||||||
host->touch(true);
|
|
||||||
|
|
||||||
hpool->update_monitoring(host);
|
hpool->update(host);
|
||||||
|
|
||||||
hpool->update(host);
|
host->unlock();
|
||||||
|
|
||||||
host->unlock();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
host->unlock();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,6 +78,15 @@ void MonitorThread::do_message()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( host->get_state() == Host::OFFLINE ) //Should not receive any info
|
||||||
|
{
|
||||||
|
delete hinfo;
|
||||||
|
|
||||||
|
host->unlock();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
// Monitoring Error. VMs running on the host are moved to UNKNOWN
|
// Monitoring Error. VMs running on the host are moved to UNKNOWN
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
@ -181,8 +190,6 @@ void MonitorThread::do_message()
|
|||||||
rc = host->update_info(tmpl, vm_poll, lost, found, non_shared_ds,
|
rc = host->update_info(tmpl, vm_poll, lost, found, non_shared_ds,
|
||||||
reserved_cpu, reserved_mem);
|
reserved_cpu, reserved_mem);
|
||||||
|
|
||||||
hpool->update(host);
|
|
||||||
|
|
||||||
if (rc != 0)
|
if (rc != 0)
|
||||||
{
|
{
|
||||||
host->unlock();
|
host->unlock();
|
||||||
@ -190,6 +197,8 @@ void MonitorThread::do_message()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
hpool->update(host);
|
||||||
|
|
||||||
hpool->update_monitoring(host);
|
hpool->update_monitoring(host);
|
||||||
|
|
||||||
oss << "Host " << host->get_name() << " (" << host->get_oid() << ")"
|
oss << "Host " << host->get_name() << " (" << host->get_oid() << ")"
|
||||||
|
@ -24,28 +24,35 @@ module OpenNebula
|
|||||||
# Constants and Class Methods
|
# Constants and Class Methods
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
||||||
|
|
||||||
HOST_METHODS = {
|
HOST_METHODS = {
|
||||||
:info => "host.info",
|
:info => "host.info",
|
||||||
:allocate => "host.allocate",
|
:allocate => "host.allocate",
|
||||||
:delete => "host.delete",
|
:delete => "host.delete",
|
||||||
:enable => "host.enable",
|
:status => "host.status",
|
||||||
:update => "host.update",
|
:update => "host.update",
|
||||||
:monitoring => "host.monitoring",
|
:monitoring => "host.monitoring",
|
||||||
:rename => "host.rename"
|
:rename => "host.rename"
|
||||||
}
|
}
|
||||||
|
|
||||||
HOST_STATES=%w{INIT MONITORING_MONITORED MONITORED ERROR DISABLED MONITORING_ERROR MONITORING_INIT MONITORING_DISABLED}
|
HOST_STATES=%w{INIT MONITORING_MONITORED MONITORED ERROR DISABLED
|
||||||
|
MONITORING_ERROR MONITORING_INIT MONITORING_DISABLED OFFLINE}
|
||||||
|
|
||||||
SHORT_HOST_STATES={
|
SHORT_HOST_STATES={
|
||||||
"INIT" => "init",
|
"INIT" => "init",
|
||||||
"MONITORING_MONITORED" => "update",
|
"MONITORING_MONITORED" => "update",
|
||||||
"MONITORED" => "on",
|
"MONITORED" => "on",
|
||||||
"ERROR" => "err",
|
"ERROR" => "err",
|
||||||
"DISABLED" => "off",
|
"DISABLED" => "dsbl",
|
||||||
"MONITORING_ERROR" => "retry",
|
"MONITORING_ERROR" => "retry",
|
||||||
"MONITORING_INIT" => "init",
|
"MONITORING_INIT" => "init",
|
||||||
"MONITORING_DISABLED" => "off"
|
"MONITORING_DISABLED" => "dsbl",
|
||||||
|
"OFFLINE" => "off"
|
||||||
|
}
|
||||||
|
|
||||||
|
HOST_STATUS={
|
||||||
|
"ENABLED" => 0,
|
||||||
|
"DISABLED" => 1,
|
||||||
|
"OFFLINE" => 2
|
||||||
}
|
}
|
||||||
|
|
||||||
# Creates a Host description with just its identifier
|
# Creates a Host description with just its identifier
|
||||||
@ -104,12 +111,17 @@ module OpenNebula
|
|||||||
|
|
||||||
# Enables the Host
|
# Enables the Host
|
||||||
def enable()
|
def enable()
|
||||||
set_enabled(true)
|
set_status("ENABLED")
|
||||||
end
|
end
|
||||||
|
|
||||||
# Disables the Host
|
# Disables the Host
|
||||||
def disable()
|
def disable()
|
||||||
set_enabled(false)
|
set_status("DISABLED")
|
||||||
|
end
|
||||||
|
|
||||||
|
# Sets the Host offline
|
||||||
|
def offline()
|
||||||
|
set_status("OFFLINE")
|
||||||
end
|
end
|
||||||
|
|
||||||
def flush()
|
def flush()
|
||||||
@ -255,10 +267,10 @@ module OpenNebula
|
|||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def set_enabled(enabled)
|
def set_status(status)
|
||||||
return Error.new('ID not defined') if !@pe_id
|
return Error.new('ID not defined') if !@pe_id
|
||||||
|
|
||||||
rc = @client.call(HOST_METHODS[:enable], @pe_id, enabled)
|
rc = @client.call(HOST_METHODS[:status], @pe_id, HOST_STATUS[status])
|
||||||
rc = nil if !OpenNebula.is_error?(rc)
|
rc = nil if !OpenNebula.is_error?(rc)
|
||||||
|
|
||||||
return rc
|
return rc
|
||||||
|
@ -414,7 +414,7 @@ void RequestManager::register_xml_methods()
|
|||||||
xmlrpc_c::methodPtr vrouter_pool_info(new VirtualRouterPoolInfo());
|
xmlrpc_c::methodPtr vrouter_pool_info(new VirtualRouterPoolInfo());
|
||||||
|
|
||||||
// Host Methods
|
// Host Methods
|
||||||
xmlrpc_c::methodPtr host_enable(new HostEnable());
|
xmlrpc_c::methodPtr host_status(new HostStatus());
|
||||||
xmlrpc_c::methodPtr host_monitoring(new HostMonitoring());
|
xmlrpc_c::methodPtr host_monitoring(new HostMonitoring());
|
||||||
xmlrpc_c::methodPtr host_pool_monitoring(new HostPoolMonitoring());
|
xmlrpc_c::methodPtr host_pool_monitoring(new HostPoolMonitoring());
|
||||||
|
|
||||||
@ -527,7 +527,7 @@ void RequestManager::register_xml_methods()
|
|||||||
RequestManagerRegistry.addMethod("one.templatepool.info",template_pool_info);
|
RequestManagerRegistry.addMethod("one.templatepool.info",template_pool_info);
|
||||||
|
|
||||||
/* Host related methods*/
|
/* Host related methods*/
|
||||||
RequestManagerRegistry.addMethod("one.host.enable", host_enable);
|
RequestManagerRegistry.addMethod("one.host.status", host_status);
|
||||||
RequestManagerRegistry.addMethod("one.host.update", host_update);
|
RequestManagerRegistry.addMethod("one.host.update", host_update);
|
||||||
RequestManagerRegistry.addMethod("one.host.allocate", host_allocate);
|
RequestManagerRegistry.addMethod("one.host.allocate", host_allocate);
|
||||||
RequestManagerRegistry.addMethod("one.host.delete", host_delete);
|
RequestManagerRegistry.addMethod("one.host.delete", host_delete);
|
||||||
|
@ -262,14 +262,10 @@ Request::ErrorCode TemplateDelete::request_execute(
|
|||||||
|
|
||||||
int HostDelete::drop(int oid, PoolObjectSQL * object, string& error_msg)
|
int HostDelete::drop(int oid, PoolObjectSQL * object, string& error_msg)
|
||||||
{
|
{
|
||||||
Nebula& nd = Nebula::instance();
|
InformationManager * im = Nebula::instance().get_im();
|
||||||
InformationManager * im = nd.get_im();
|
|
||||||
|
|
||||||
HostPool * hpool = nd.get_hpool();
|
|
||||||
|
|
||||||
Host* host = static_cast<Host *>(object);
|
Host* host = static_cast<Host *>(object);
|
||||||
|
|
||||||
//Do not trigger delete event on IM if there are VMs running on the host
|
|
||||||
if ( host->get_share_running_vms() > 0 )
|
if ( host->get_share_running_vms() > 0 )
|
||||||
{
|
{
|
||||||
error_msg = "Can not remove a host with running VMs";
|
error_msg = "Can not remove a host with running VMs";
|
||||||
@ -279,13 +275,12 @@ int HostDelete::drop(int oid, PoolObjectSQL * object, string& error_msg)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
host->disable();
|
string im_mad = host->get_im_mad();
|
||||||
|
string name = host->get_name();
|
||||||
|
|
||||||
hpool->update(host);
|
RequestManagerDelete::drop(oid, object, error_msg);
|
||||||
|
|
||||||
host->unlock();
|
im->stop_monitor(oid, name, im_mad);
|
||||||
|
|
||||||
im->trigger(InformationManager::STOPMONITOR, oid);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -20,13 +20,11 @@
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
|
|
||||||
void HostEnable::request_execute(xmlrpc_c::paramList const& paramList,
|
void HostStatus::request_execute(xmlrpc_c::paramList const& paramList,
|
||||||
RequestAttributes& att)
|
RequestAttributes& att)
|
||||||
{
|
{
|
||||||
int id = xmlrpc_c::value_int(paramList.getInt(1));
|
int id = xmlrpc_c::value_int(paramList.getInt(1));
|
||||||
bool enable = xmlrpc_c::value_boolean(paramList.getBoolean(2));
|
int status = xmlrpc_c::value_int(paramList.getInt(2));
|
||||||
|
|
||||||
Host * host;
|
|
||||||
|
|
||||||
HostPool * hpool = static_cast<HostPool *>(pool);
|
HostPool * hpool = static_cast<HostPool *>(pool);
|
||||||
|
|
||||||
@ -35,7 +33,7 @@ void HostEnable::request_execute(xmlrpc_c::paramList const& paramList,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
host = hpool->get(id,true);
|
Host * host = hpool->get(id,true);
|
||||||
|
|
||||||
if ( host == 0 )
|
if ( host == 0 )
|
||||||
{
|
{
|
||||||
@ -45,13 +43,23 @@ void HostEnable::request_execute(xmlrpc_c::paramList const& paramList,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( enable == true)
|
switch (status)
|
||||||
{
|
{
|
||||||
host->enable();
|
case ENABLED:
|
||||||
}
|
host->enable();
|
||||||
else
|
break;
|
||||||
{
|
case DISABLED:
|
||||||
host->disable();
|
host->disable();
|
||||||
|
break;
|
||||||
|
case OFFLINE:
|
||||||
|
host->offline();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
att.resp_msg = "Wrong status code";
|
||||||
|
failure_response(INTERNAL, att);
|
||||||
|
|
||||||
|
host->unlock();
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
hpool->update(host);
|
hpool->update(host);
|
||||||
|
@ -341,6 +341,16 @@ int RequestManagerVirtualMachine::get_host_information(
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( host->get_state() == Host::OFFLINE )
|
||||||
|
{
|
||||||
|
att.resp_msg = "Host is offline, cannot use it to deploy VM";
|
||||||
|
failure_response(ACTION, att);
|
||||||
|
|
||||||
|
host->unlock();
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
name = host->get_name();
|
name = host->get_name();
|
||||||
vmm = host->get_vmm_mad();
|
vmm = host->get_vmm_mad();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user