mirror of
https://github.com/OpenNebula/one.git
synced 2025-01-05 09:17:41 +03:00
M #-: Showback option to calculate only running VM (#1105)
(cherry picked from commit c5ad2698b7
)
This commit is contained in:
parent
b2a5b743ad
commit
6bca41f0db
@ -723,6 +723,14 @@ public:
|
|||||||
to_xml_extended(history->vm_info, 0);
|
to_xml_extended(history->vm_info, 0);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets end time of a VM
|
||||||
|
*/
|
||||||
|
time_t get_etime()
|
||||||
|
{
|
||||||
|
return history->etime;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets end time of a VM in the previous Host. It also sets the vm_info
|
* Sets end time of a VM in the previous Host. It also sets the vm_info
|
||||||
* when the record is closed
|
* when the record is closed
|
||||||
@ -779,6 +787,14 @@ public:
|
|||||||
history->running_etime = _etime;
|
history->running_etime = _etime;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the running end time for the VM
|
||||||
|
*/
|
||||||
|
time_t get_running_etime() const
|
||||||
|
{
|
||||||
|
return history->running_etime;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets end time of VM running state in the previous host.
|
* Sets end time of VM running state in the previous host.
|
||||||
* @param _etime time when the running state finished
|
* @param _etime time when the running state finished
|
||||||
|
@ -36,7 +36,8 @@ public:
|
|||||||
bool on_hold,
|
bool on_hold,
|
||||||
float default_cpu_cost,
|
float default_cpu_cost,
|
||||||
float default_mem_cost,
|
float default_mem_cost,
|
||||||
float default_disk_cost);
|
float default_disk_cost,
|
||||||
|
bool showback_only_running);
|
||||||
|
|
||||||
~VirtualMachinePool(){};
|
~VirtualMachinePool(){};
|
||||||
|
|
||||||
@ -431,6 +432,15 @@ private:
|
|||||||
float _default_mem_cost;
|
float _default_mem_cost;
|
||||||
float _default_disk_cost;
|
float _default_disk_cost;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Switch for showback cpu and memory cost calculation
|
||||||
|
* - true: count only running VMs for CPU and MEMORY
|
||||||
|
* - false: include reservations for CPU and MEMORY
|
||||||
|
* this includes poweroff and suspended VM states
|
||||||
|
* note: datastore cost is always counted in poweroff and suspended state
|
||||||
|
*/
|
||||||
|
bool _showback_only_running;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Callback used to get an int in the DB it is used by VM Pool in:
|
* Callback used to get an int in the DB it is used by VM Pool in:
|
||||||
* - calculate_showback (min_stime)
|
* - calculate_showback (min_stime)
|
||||||
|
@ -207,6 +207,11 @@ DEFAULT_COST = [
|
|||||||
DISK_COST = 0
|
DISK_COST = 0
|
||||||
]
|
]
|
||||||
|
|
||||||
|
# Should showback calculation count only running VMs.
|
||||||
|
# If 'no' showback will inlcude also reserved CPU and MEMORY, e.g. VM states
|
||||||
|
# POWEROFF or SUSPENDED
|
||||||
|
SHOWBACK_ONLY_RUNNING = "no"
|
||||||
|
|
||||||
#*******************************************************************************
|
#*******************************************************************************
|
||||||
# XML-RPC server configuration
|
# XML-RPC server configuration
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
|
@ -1299,8 +1299,16 @@ static void close_cp_history(VirtualMachinePool *vmpool, VirtualMachine *vm,
|
|||||||
VMActions::Action action, const RequestAttributes& ra)
|
VMActions::Action action, const RequestAttributes& ra)
|
||||||
{
|
{
|
||||||
time_t the_time = time(0);
|
time_t the_time = time(0);
|
||||||
|
bool set_retime = false;
|
||||||
|
|
||||||
|
if (vm->get_running_etime() == 0)
|
||||||
|
{
|
||||||
vm->set_running_etime(the_time);
|
vm->set_running_etime(the_time);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
set_retime = true;
|
||||||
|
}
|
||||||
|
|
||||||
vm->set_etime(the_time);
|
vm->set_etime(the_time);
|
||||||
|
|
||||||
@ -1318,6 +1326,11 @@ static void close_cp_history(VirtualMachinePool *vmpool, VirtualMachine *vm,
|
|||||||
|
|
||||||
vm->set_running_stime(the_time);
|
vm->set_running_stime(the_time);
|
||||||
|
|
||||||
|
if (set_retime) //Keep VM not running
|
||||||
|
{
|
||||||
|
vm->set_running_etime(the_time);
|
||||||
|
}
|
||||||
|
|
||||||
vmpool->insert_history(vm);
|
vmpool->insert_history(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1743,7 +1756,14 @@ int DispatchManager::attach_nic(int vid, VirtualMachineTemplate* tmpl,
|
|||||||
vm->log("DiM", Log::INFO, "VM NIC Successfully attached.");
|
vm->log("DiM", Log::INFO, "VM NIC Successfully attached.");
|
||||||
|
|
||||||
vm->clear_attach_nic();
|
vm->clear_attach_nic();
|
||||||
|
|
||||||
vmpool->update_search(vm.get());
|
vmpool->update_search(vm.get());
|
||||||
|
|
||||||
|
time_t the_time = time(0);
|
||||||
|
|
||||||
|
vm->set_running_etime(the_time);
|
||||||
|
|
||||||
|
vmpool->update_history(vm.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
vmpool->update(vm.get());
|
||||||
|
@ -49,6 +49,12 @@ void DispatchManager::trigger_suspend_success(int vid)
|
|||||||
|
|
||||||
vm->set_state(VirtualMachine::LCM_INIT);
|
vm->set_state(VirtualMachine::LCM_INIT);
|
||||||
|
|
||||||
|
time_t the_time = time(0);
|
||||||
|
|
||||||
|
vm->set_running_etime(the_time);
|
||||||
|
|
||||||
|
vmpool->update_history(vm.get());
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
vmpool->update(vm.get());
|
||||||
|
|
||||||
int uid = vm->get_uid();
|
int uid = vm->get_uid();
|
||||||
@ -216,6 +222,12 @@ void DispatchManager::trigger_poweroff_success(int vid)
|
|||||||
|
|
||||||
vm->set_state(VirtualMachine::LCM_INIT);
|
vm->set_state(VirtualMachine::LCM_INIT);
|
||||||
|
|
||||||
|
time_t the_time = time(0);
|
||||||
|
|
||||||
|
vm->set_running_etime(the_time);
|
||||||
|
|
||||||
|
vmpool->update_history(vm.get());
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
vmpool->update(vm.get());
|
||||||
|
|
||||||
int uid = vm->get_uid();
|
int uid = vm->get_uid();
|
||||||
|
@ -751,8 +751,6 @@ void LifeCycleManager::trigger_restore(int vid, const RequestAttributes& ra)
|
|||||||
|
|
||||||
vm->set_etime(the_time);
|
vm->set_etime(the_time);
|
||||||
|
|
||||||
vm->set_running_etime(the_time);
|
|
||||||
|
|
||||||
vmpool->update_history(vm.get());
|
vmpool->update_history(vm.get());
|
||||||
|
|
||||||
vm->cp_history();
|
vm->cp_history();
|
||||||
@ -814,8 +812,6 @@ void LifeCycleManager::trigger_restart(int vid, const RequestAttributes& ra)
|
|||||||
|
|
||||||
vm->set_etime(the_time);
|
vm->set_etime(the_time);
|
||||||
|
|
||||||
vm->set_running_etime(the_time);
|
|
||||||
|
|
||||||
vmpool->update_history(vm.get());
|
vmpool->update_history(vm.get());
|
||||||
|
|
||||||
vm->cp_history();
|
vm->cp_history();
|
||||||
@ -1006,7 +1002,10 @@ void LifeCycleManager::clean_up_vm(VirtualMachine * vm, bool dispose,
|
|||||||
vm->delete_snapshots();
|
vm->delete_snapshots();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (vm->get_etime() == 0)
|
||||||
|
{
|
||||||
vm->set_etime(the_time);
|
vm->set_etime(the_time);
|
||||||
|
}
|
||||||
|
|
||||||
vm->get_capacity(sr);
|
vm->get_capacity(sr);
|
||||||
|
|
||||||
|
@ -304,20 +304,14 @@ void LifeCycleManager::trigger_deploy_success(int vid)
|
|||||||
vm->get_lcm_state() == VirtualMachine::BOOT_UNDEPLOY_FAILURE ||
|
vm->get_lcm_state() == VirtualMachine::BOOT_UNDEPLOY_FAILURE ||
|
||||||
vm->get_lcm_state() == VirtualMachine::BOOT_FAILURE )
|
vm->get_lcm_state() == VirtualMachine::BOOT_FAILURE )
|
||||||
{
|
{
|
||||||
if ( vm->get_lcm_state() == VirtualMachine::BOOT_SUSPENDED ||
|
|
||||||
vm->get_lcm_state() == VirtualMachine::BOOT_POWEROFF )
|
|
||||||
{
|
|
||||||
vm->set_previous_etime(time(0));
|
|
||||||
|
|
||||||
vm->set_previous_running_etime(time(0));
|
|
||||||
|
|
||||||
vmpool->update_previous_history(vm.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
vm->set_state(VirtualMachine::RUNNING);
|
vm->set_state(VirtualMachine::RUNNING);
|
||||||
|
|
||||||
vm->clear_action();
|
vm->clear_action();
|
||||||
|
|
||||||
|
vm->set_etime(0);
|
||||||
|
|
||||||
|
vm->set_running_etime(0);
|
||||||
|
|
||||||
vmpool->update_history(vm.get());
|
vmpool->update_history(vm.get());
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
vmpool->update(vm.get());
|
||||||
@ -342,12 +336,12 @@ void LifeCycleManager::trigger_deploy_failure(int vid)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
time_t the_time = time(0);
|
||||||
|
|
||||||
if ( vm->get_lcm_state() == VirtualMachine::MIGRATE )
|
if ( vm->get_lcm_state() == VirtualMachine::MIGRATE )
|
||||||
{
|
{
|
||||||
HostShareCapacity sr;
|
HostShareCapacity sr;
|
||||||
|
|
||||||
time_t the_time = time(0);
|
|
||||||
|
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
// RUNNING STATE FROM MIGRATE
|
// RUNNING STATE FROM MIGRATE
|
||||||
//----------------------------------------------------
|
//----------------------------------------------------
|
||||||
@ -384,50 +378,42 @@ void LifeCycleManager::trigger_deploy_failure(int vid)
|
|||||||
|
|
||||||
vm->log("LCM", Log::INFO, "Fail to live migrate VM."
|
vm->log("LCM", Log::INFO, "Fail to live migrate VM."
|
||||||
" Assuming that the VM is still RUNNING.");
|
" Assuming that the VM is still RUNNING.");
|
||||||
|
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
else if (vm->get_lcm_state() == VirtualMachine::BOOT)
|
else if (vm->get_lcm_state() == VirtualMachine::BOOT)
|
||||||
{
|
{
|
||||||
vm->set_state(VirtualMachine::BOOT_FAILURE);
|
vm->set_state(VirtualMachine::BOOT_FAILURE);
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
|
||||||
}
|
}
|
||||||
else if (vm->get_lcm_state() == VirtualMachine::BOOT_MIGRATE)
|
else if (vm->get_lcm_state() == VirtualMachine::BOOT_MIGRATE)
|
||||||
{
|
{
|
||||||
vm->set_state(VirtualMachine::BOOT_MIGRATE_FAILURE);
|
vm->set_state(VirtualMachine::BOOT_MIGRATE_FAILURE);
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
|
||||||
}
|
}
|
||||||
else if (vm->get_lcm_state() == VirtualMachine::BOOT_UNKNOWN)
|
else if (vm->get_lcm_state() == VirtualMachine::BOOT_UNKNOWN)
|
||||||
{
|
{
|
||||||
vm->set_state(VirtualMachine::UNKNOWN);
|
vm->set_state(VirtualMachine::UNKNOWN);
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
|
||||||
}
|
}
|
||||||
else if (vm->get_lcm_state() == VirtualMachine::BOOT_POWEROFF)
|
else if (vm->get_lcm_state() == VirtualMachine::BOOT_POWEROFF)
|
||||||
{
|
{
|
||||||
vm->set_state(VirtualMachine::POWEROFF);
|
vm->set_state(VirtualMachine::POWEROFF);
|
||||||
vm->set_state(VirtualMachine::LCM_INIT);
|
vm->set_state(VirtualMachine::LCM_INIT);
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
|
||||||
}
|
}
|
||||||
else if (vm->get_lcm_state() == VirtualMachine::BOOT_SUSPENDED)
|
else if (vm->get_lcm_state() == VirtualMachine::BOOT_SUSPENDED)
|
||||||
{
|
{
|
||||||
vm->set_state(VirtualMachine::SUSPENDED);
|
vm->set_state(VirtualMachine::SUSPENDED);
|
||||||
vm->set_state(VirtualMachine::LCM_INIT);
|
vm->set_state(VirtualMachine::LCM_INIT);
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
|
||||||
}
|
}
|
||||||
else if (vm->get_lcm_state() == VirtualMachine::BOOT_STOPPED)
|
else if (vm->get_lcm_state() == VirtualMachine::BOOT_STOPPED)
|
||||||
{
|
{
|
||||||
vm->set_state(VirtualMachine::BOOT_STOPPED_FAILURE);
|
vm->set_state(VirtualMachine::BOOT_STOPPED_FAILURE);
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
vm->set_etime(the_time);
|
||||||
}
|
}
|
||||||
else if (vm->get_lcm_state() == VirtualMachine::BOOT_UNDEPLOY)
|
else if (vm->get_lcm_state() == VirtualMachine::BOOT_UNDEPLOY)
|
||||||
{
|
{
|
||||||
vm->set_state(VirtualMachine::BOOT_UNDEPLOY_FAILURE);
|
vm->set_state(VirtualMachine::BOOT_UNDEPLOY_FAILURE);
|
||||||
|
|
||||||
vmpool->update(vm.get());
|
vm->set_etime(the_time);
|
||||||
}
|
}
|
||||||
//wrong state + recover failure from failure state
|
//wrong state + recover failure from failure state
|
||||||
else if ( vm->get_lcm_state() != VirtualMachine::BOOT_FAILURE &&
|
else if ( vm->get_lcm_state() != VirtualMachine::BOOT_FAILURE &&
|
||||||
@ -437,6 +423,12 @@ void LifeCycleManager::trigger_deploy_failure(int vid)
|
|||||||
{
|
{
|
||||||
vm->log("LCM",Log::ERROR,"deploy_failure_action, VM in a wrong state");
|
vm->log("LCM",Log::ERROR,"deploy_failure_action, VM in a wrong state");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
vm->set_running_etime(the_time);
|
||||||
|
|
||||||
|
vmpool->update_history(vm.get());
|
||||||
|
|
||||||
|
vmpool->update(vm.get());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -660,6 +660,7 @@ void Nebula::start(bool bootstrap_only)
|
|||||||
float cpu_cost;
|
float cpu_cost;
|
||||||
float mem_cost;
|
float mem_cost;
|
||||||
float disk_cost;
|
float disk_cost;
|
||||||
|
bool showback_only_running;
|
||||||
|
|
||||||
const VectorAttribute * default_cost;
|
const VectorAttribute * default_cost;
|
||||||
|
|
||||||
@ -686,8 +687,10 @@ void Nebula::start(bool bootstrap_only)
|
|||||||
disk_cost = 0;
|
disk_cost = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
nebula_configuration->get("SHOWBACK_ONLY_RUNNING", showback_only_running);
|
||||||
|
|
||||||
vmpool = new VirtualMachinePool(logdb, vm_restricted_attrs, vm_encrypted_attrs,
|
vmpool = new VirtualMachinePool(logdb, vm_restricted_attrs, vm_encrypted_attrs,
|
||||||
vm_submit_on_hold, cpu_cost, mem_cost, disk_cost);
|
vm_submit_on_hold, cpu_cost, mem_cost, disk_cost, showback_only_running);
|
||||||
|
|
||||||
/* ---------------------------- Host Pool --------------------------- */
|
/* ---------------------------- Host Pool --------------------------- */
|
||||||
vector<const SingleAttribute *> host_encrypted_attrs;
|
vector<const SingleAttribute *> host_encrypted_attrs;
|
||||||
|
@ -362,6 +362,7 @@ void OpenNebulaTemplate::set_conf_default()
|
|||||||
# VM_SUBMIT_ON_HOLD
|
# VM_SUBMIT_ON_HOLD
|
||||||
# API_LIST_ORDER
|
# API_LIST_ORDER
|
||||||
# VNC_PORTS
|
# VNC_PORTS
|
||||||
|
# SHOWBACK_ONLY_RUNNING
|
||||||
#*******************************************************************************
|
#*******************************************************************************
|
||||||
*/
|
*/
|
||||||
set_conf_single("MANAGER_TIMER", "15");
|
set_conf_single("MANAGER_TIMER", "15");
|
||||||
@ -382,7 +383,7 @@ void OpenNebulaTemplate::set_conf_default()
|
|||||||
set_conf_single("HOST_ENCRYPTED_ATTR", "VCENTER_PASSWORD");
|
set_conf_single("HOST_ENCRYPTED_ATTR", "VCENTER_PASSWORD");
|
||||||
set_conf_single("HOST_ENCRYPTED_ATTR", "NSX_PASSWORD");
|
set_conf_single("HOST_ENCRYPTED_ATTR", "NSX_PASSWORD");
|
||||||
set_conf_single("HOST_ENCRYPTED_ATTR", "ONE_PASSWORD");
|
set_conf_single("HOST_ENCRYPTED_ATTR", "ONE_PASSWORD");
|
||||||
|
set_conf_single("SHOWBACK_ONLY_RUNNING", "NO");
|
||||||
|
|
||||||
//DB CONFIGURATION
|
//DB CONFIGURATION
|
||||||
vvalue.insert(make_pair("BACKEND","sqlite"));
|
vvalue.insert(make_pair("BACKEND","sqlite"));
|
||||||
|
@ -36,11 +36,13 @@ VirtualMachinePool::VirtualMachinePool(
|
|||||||
bool on_hold,
|
bool on_hold,
|
||||||
float default_cpu_cost,
|
float default_cpu_cost,
|
||||||
float default_mem_cost,
|
float default_mem_cost,
|
||||||
float default_disk_cost)
|
float default_disk_cost,
|
||||||
|
bool showback_only_running)
|
||||||
: PoolSQL(db, one_db::vm_table),
|
: PoolSQL(db, one_db::vm_table),
|
||||||
_submit_on_hold(on_hold),
|
_submit_on_hold(on_hold),
|
||||||
_default_cpu_cost(default_cpu_cost), _default_mem_cost(default_mem_cost),
|
_default_cpu_cost(default_cpu_cost), _default_mem_cost(default_mem_cost),
|
||||||
_default_disk_cost(default_disk_cost)
|
_default_disk_cost(default_disk_cost),
|
||||||
|
_showback_only_running(showback_only_running)
|
||||||
{
|
{
|
||||||
// Set restricted attributes
|
// Set restricted attributes
|
||||||
VirtualMachineTemplate::parse_restricted(restricted_attrs);
|
VirtualMachineTemplate::parse_restricted(restricted_attrs);
|
||||||
@ -575,8 +577,8 @@ int VirtualMachinePool::calculate_showback(
|
|||||||
|
|
||||||
tm tmp_tm;
|
tm tmp_tm;
|
||||||
int vid;
|
int vid;
|
||||||
int h_stime;
|
time_t h_stime, h_rstime;
|
||||||
int h_etime;
|
time_t h_etime, h_retime;
|
||||||
float cpu_cost;
|
float cpu_cost;
|
||||||
float mem_cost;
|
float mem_cost;
|
||||||
float disk_cost;
|
float disk_cost;
|
||||||
@ -719,8 +721,11 @@ int VirtualMachinePool::calculate_showback(
|
|||||||
|
|
||||||
history.xpath(vid, "/HISTORY/OID", -1);
|
history.xpath(vid, "/HISTORY/OID", -1);
|
||||||
|
|
||||||
history.xpath(h_stime, "/HISTORY/STIME", 0);
|
history.xpath(h_stime, "/HISTORY/STIME", (time_t)0);
|
||||||
history.xpath(h_etime, "/HISTORY/ETIME", 0);
|
history.xpath(h_etime, "/HISTORY/ETIME", (time_t)0);
|
||||||
|
|
||||||
|
history.xpath(h_rstime, "/HISTORY/RSTIME", (time_t)0);
|
||||||
|
history.xpath(h_retime, "/HISTORY/RETIME", (time_t)0);
|
||||||
|
|
||||||
history.xpath<float>(cpu, "/HISTORY/VM/TEMPLATE/CPU", 0.0);
|
history.xpath<float>(cpu, "/HISTORY/VM/TEMPLATE/CPU", 0.0);
|
||||||
history.xpath(mem, "/HISTORY/VM/TEMPLATE/MEMORY", 0);
|
history.xpath(mem, "/HISTORY/VM/TEMPLATE/MEMORY", 0);
|
||||||
@ -761,17 +766,19 @@ int VirtualMachinePool::calculate_showback(
|
|||||||
time_t t = *slot_it;
|
time_t t = *slot_it;
|
||||||
time_t t_next = *(slot_it+1);
|
time_t t_next = *(slot_it+1);
|
||||||
|
|
||||||
if( (h_etime > t || h_etime == 0) &&
|
auto count_sb_record = [&](time_t st, time_t et, bool cpu_mem, bool disk_total)
|
||||||
(h_stime != 0 && h_stime <= t_next) ) {
|
{
|
||||||
|
if( (et > t || et == 0) &&
|
||||||
|
(st != 0 && st <= t_next) ) {
|
||||||
|
|
||||||
time_t stime = t;
|
time_t stime = t;
|
||||||
if(h_stime != 0){
|
if(st != 0){
|
||||||
stime = (t < h_stime) ? h_stime : t; //max(t, h_stime);
|
stime = max(t, st);
|
||||||
}
|
}
|
||||||
|
|
||||||
time_t etime = t_next;
|
time_t etime = t_next;
|
||||||
if(h_etime != 0){
|
if(et != 0){
|
||||||
etime = (t_next < h_etime) ? t_next : h_etime; //min(t_next, h_etime);
|
etime = min(t_next, et);
|
||||||
}
|
}
|
||||||
|
|
||||||
float n_hours = difftime(etime, stime) / 60 / 60;
|
float n_hours = difftime(etime, stime) / 60 / 60;
|
||||||
@ -779,12 +786,29 @@ int VirtualMachinePool::calculate_showback(
|
|||||||
// Add to vm time slot.
|
// Add to vm time slot.
|
||||||
SBRecord& totals = vm_cost.totals[t];
|
SBRecord& totals = vm_cost.totals[t];
|
||||||
|
|
||||||
|
if (cpu_mem)
|
||||||
|
{
|
||||||
totals.cpu_cost += cpu_cost * cpu * n_hours;
|
totals.cpu_cost += cpu_cost * cpu * n_hours;
|
||||||
totals.mem_cost += mem_cost * mem * n_hours;
|
totals.mem_cost += mem_cost * mem * n_hours;
|
||||||
|
}
|
||||||
|
if (disk_total)
|
||||||
|
{
|
||||||
totals.disk_cost+= disk_cost* disk* n_hours;
|
totals.disk_cost+= disk_cost* disk* n_hours;
|
||||||
totals.hours += n_hours;
|
totals.hours += n_hours;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if (_showback_only_running)
|
||||||
|
{
|
||||||
|
count_sb_record(h_stime, h_etime, false, true);
|
||||||
|
count_sb_record(h_rstime, h_retime, true, false);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
count_sb_record(h_stime, h_etime, true, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
xml.free_nodes(nodes);
|
xml.free_nodes(nodes);
|
||||||
|
Loading…
Reference in New Issue
Block a user