mirror of
https://github.com/OpenNebula/one.git
synced 2025-02-01 05:47:01 +03:00
865908de1c
co-authored-by: Pavel Czerný <pczerny@opennebula.systems> co-authored-by: Frederick Borges <fborges@opennebula.io> co-authored-by: Christian González <cgonzalez@opennebula.io> * VNET updates trigger a driver action on running VMs with NICs in the network. * VNET includes a sets with VM status: updated, outdated, error and updating. With VMs in each state. * VNET flags error situations with a new state UPDATE_FAILURE. * The same procedure is applied when an AR is updated (only VMs in that AR are updated). * A new options in the one.vn.recover API call enable to recover or retry this VM update operations. * The following attributes can be live-updated per VNET driver: - PHYDEV (novlan, vlan, ovs driver) - MTU (vlan, ovs driver) - VLAN_ID (vlan, ovs driver) - QINQ_TYPE (ovs driver) - CVLANS (ovs driver) - VLAN_TAGGED_ID (ovs driver) - OUTER_VLAN_ID (ovs driver) - INBOUND_AVG_BW (SG, ovs driver + KVM) - INBOUND_PEAK_BW (SG, ovs driver + KVM) - INBOUND_PEAK_KB (SG, ovs driver + KVM) - OUTBOUND_AVG_BW (SG, ovs driver + KVM) - OUTBOUND_PEAK_BW (SG, ovs driver + KVM) - OUTBOUND_PEAK_KB (SG, ovs driver + KVM) * New API call one.vm.updatenic, allows to update individual NICs without the need of detach/attach (only QoS supported). * Update operations for: 802.1Q, bridge, fw, ovswitch, ovswitch_vxlan and vxlan network drivers. * VNET attributes (old values) stored in VNET_UPDATE to allow implementation of update operations. The attribute is removed after a successful update. * Updates to CLI onevnet (--retry option) / onevm (nicupdate command) * XSD files updated to reflect the new data model * Ruby and JAVA bindings updated: new VNET state and recover option, new VM API call. * Suntone and Fireedge implementation (lease status, recover option, new states) TODO: Virtual Functions does not support this functionality iii
154 lines
4.2 KiB
C++
154 lines
4.2 KiB
C++
/* -------------------------------------------------------------------------- */
|
|
/* Copyright 2002-2022, OpenNebula Project, OpenNebula Systems */
|
|
/* */
|
|
/* 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 OBJECT_COLLECTION_H_
|
|
#define OBJECT_COLLECTION_H_
|
|
|
|
#include <set>
|
|
#include <string>
|
|
#include <libxml/tree.h>
|
|
|
|
class ObjectXML;
|
|
|
|
/**
|
|
* Class to store a set of PoolObjectSQL IDs.
|
|
*/
|
|
class ObjectCollection
|
|
{
|
|
public:
|
|
|
|
ObjectCollection(const std::string& _collection_name)
|
|
:collection_name(_collection_name){};
|
|
|
|
ObjectCollection(const std::string& cname, const std::set<int>& cset)
|
|
:collection_name(cname), collection_set(cset){};
|
|
|
|
~ObjectCollection(){};
|
|
|
|
/**
|
|
* Adds an ID to the set.
|
|
* @param id The new id
|
|
*
|
|
* @return 0 on success, -1 if the ID was already in the set
|
|
*/
|
|
int add(int id);
|
|
|
|
/**
|
|
* Deletes an ID from the set.
|
|
* @param id The id
|
|
*
|
|
* @return 0 on success, -1 if the ID was not in the set
|
|
*/
|
|
int del(int id);
|
|
|
|
/**
|
|
* Deletes all IDs from the set.
|
|
*/
|
|
void clear()
|
|
{
|
|
collection_set.clear();
|
|
}
|
|
|
|
/**
|
|
* Returns how many IDs are there in the set.
|
|
* @return how many IDs are there in the set.
|
|
*/
|
|
int size() const
|
|
{
|
|
return collection_set.size();
|
|
};
|
|
|
|
/**
|
|
* Rebuilds the object from an xml object
|
|
* @param xml xml object
|
|
* @param xpath_prefix Parent nodes, e.g. "/DATASTORE/"
|
|
*
|
|
* @return 0 on success, -1 otherwise
|
|
*/
|
|
int from_xml(const ObjectXML* xml, const std::string& xpath_prefix);
|
|
|
|
/**
|
|
* Function to print the Collection object into a string in
|
|
* XML format
|
|
* @param xml the resulting XML string
|
|
* @return a reference to the generated string
|
|
*/
|
|
std::string& to_xml(std::string& xml) const;
|
|
|
|
/**
|
|
* Returns a reference to the IDs set
|
|
*/
|
|
const std::set<int>& get_collection() const
|
|
{
|
|
return collection_set;
|
|
};
|
|
|
|
/**
|
|
* Returns true if the collection contains the given id
|
|
* @param id ID to search
|
|
* @return true if the collection contains the given id
|
|
*/
|
|
bool contains(int id) const
|
|
{
|
|
return collection_set.count(id) > 0;
|
|
}
|
|
|
|
/**
|
|
* Returns and deletes the first element from the set
|
|
* @param the element
|
|
* @return 0 on success -1 if the set was empty
|
|
*/
|
|
int pop(int& elem);
|
|
|
|
/**
|
|
* Adds to the collection the contents of other collection
|
|
*
|
|
*/
|
|
ObjectCollection& operator<<(const ObjectCollection& r);
|
|
|
|
ObjectCollection& operator<<(const std::set<int>& r);
|
|
|
|
/**
|
|
* Compute the set difference (substract elements in the right hand side
|
|
* from this collection)
|
|
*/
|
|
ObjectCollection& operator-=(const ObjectCollection& r);
|
|
|
|
ObjectCollection& operator-=(const std::set<int>& r);
|
|
|
|
private:
|
|
|
|
/**
|
|
* The collection's name
|
|
*/
|
|
std::string collection_name;
|
|
|
|
/**
|
|
* Set containing the relations IDs
|
|
*/
|
|
std::set<int> collection_set;
|
|
|
|
/**
|
|
* Rebuilds the object from an xml node
|
|
* @param node The xml node pointer
|
|
*
|
|
* @return 0 on success, -1 otherwise
|
|
*/
|
|
int from_xml_node(const xmlNodePtr node);
|
|
};
|
|
|
|
#endif /*OBJECT_COLLECTION_H_*/
|