1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-10 01:17:40 +03:00

B OpenNebula/one#6542: Fix scheduled actions for VM in done state (#3008)

* Do not allow creating a Scheduled Action for VM in done state
* Fix removing of Scheduled Action, while terminating VM
* Fix failure output for new object types
This commit is contained in:
Pavel Czerný 2024-03-26 12:04:53 +01:00 committed by GitHub
parent be64cbdf04
commit 0b3d6136e9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 47 additions and 24 deletions

View File

@ -30,6 +30,7 @@
#include "VirtualNetworkPool.h"
#include "VirtualRouterPool.h"
#include "SecurityGroupPool.h"
#include "ScheduledActionPool.h"
using namespace std;
@ -368,6 +369,8 @@ void DispatchManager::free_vm_resources(unique_ptr<VirtualMachine> vm,
vrid = vm->get_vrouter_id();
}
std::set<int> sa_ids(vm->sched_actions().get_collection());
vm.reset(); //force unlock of vm mutex
Quotas::vm_del(uid, gid, quota_tmpl.get());
@ -391,6 +394,28 @@ void DispatchManager::free_vm_resources(unique_ptr<VirtualMachine> vm,
vrouterpool->update(vr.get());
}
}
auto sapool = Nebula::instance().get_sapool();
int rc = 0;
string error;
for (const auto& id: sa_ids)
{
if (auto sa = sapool->get(id))
{
rc += sapool->drop(sa.get(), error);
}
}
if ( rc != 0 )
{
ostringstream oss;
oss << "Some schedules for VM " << vmid << " could not be removed";
NebulaLog::log("DiM", Log::ERROR, oss);
}
}
/* -------------------------------------------------------------------------- */

View File

@ -19,7 +19,6 @@
#include "Quotas.h"
#include "Nebula.h"
#include "VirtualMachinePool.h"
#include "ScheduledActionPool.h"
using namespace std;
@ -271,30 +270,7 @@ void DispatchManager::trigger_done(int vid)
(lcm_state == VirtualMachine::EPILOG ||
lcm_state == VirtualMachine::CLEANUP_DELETE))
{
string error;
int rc = 0;
std::set<int> sa_ids(vm->sched_actions().get_collection());
free_vm_resources(std::move(vm), true);
auto sapool = Nebula::instance().get_sapool();
for (const auto& id: sa_ids)
{
if (auto sa = sapool->get(id))
{
rc += sapool->drop(sa.get(), error);
}
}
if ( rc != 0 )
{
ostringstream oss;
oss << "Some schedules for VM " << vid << " could not be removed";
NebulaLog::log("DiM", Log::ERROR, oss);
}
}
else
{

View File

@ -81,6 +81,10 @@ string Request::object_name(PoolObjectSQL::ObjectType ob)
return "virtual network template";
case PoolObjectSQL::HOOK:
return "hook";
case PoolObjectSQL::BACKUPJOB:
return "backup job";
case PoolObjectSQL::SCHEDULEDACTION:
return "scheduled action";
default:
return "-";
}

View File

@ -36,6 +36,16 @@ void RequestManagerSchedAdd::request_execute(xmlrpc_c::paramList const& paramLis
if ( auto vm = pool->get_ro<VirtualMachine>(oid) )
{
stime = vm->get_stime();
if (vm->get_state() == VirtualMachine::DONE)
{
att.resp_id = oid;
att.resp_msg = "Unable to create Scheduled Action for Virtual Machine "
+ to_string(oid) + ", it's in DONE state";
failure_response(INTERNAL, att);
return;
}
}
else
{
@ -154,6 +164,14 @@ void RequestManagerSchedDelete::request_execute(xmlrpc_c::paramList const& param
return;
}
}
else
{
att.resp_obj = PoolObjectSQL::SCHEDULEDACTION;
att.resp_id = sched_id;
failure_response(NO_EXISTS, att);
return;
}
att.resp_obj = PoolObjectSQL::SCHEDULEDACTION;
att.resp_id = sched_id;