/** * Copyright (C) 2010-2013 Eugen Feller, INRIA <eugen.feller@inria.fr> * * This file is part of Snooze, a scalable, autonomic, and * energy-aware virtual machine (VM) management framework. * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation, either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see <http://www.gnu.org/licenses>. */ package org.inria.myriads.snoozenode.groupmanager.managerpolicies.reconfiguration; import java.util.Map; import org.inria.myriads.snoozecommon.communication.localcontroller.LocalControllerDescription; import org.inria.myriads.snoozecommon.communication.virtualcluster.VirtualMachineMetaData; /** * Reconfiguration plan. * * @author Eugen Feller */ public final class ReconfigurationPlan { /** Number of used nodes. */ private int numberOfUsedNodes_; /** Number of released nodes. */ private int numberOfReleasedNodes_; /** New mapping of VMs to local controllers. */ private Map<VirtualMachineMetaData, LocalControllerDescription> mapping_; /** * Constructor. * * @param mapping The mapping * @param numberOfUsedNodes The number of used nodes * @param numberOfReleasedNodes The number of released nodes */ public ReconfigurationPlan(Map<VirtualMachineMetaData, LocalControllerDescription> mapping, int numberOfUsedNodes, int numberOfReleasedNodes) { mapping_ = mapping; numberOfUsedNodes_ = numberOfUsedNodes; numberOfReleasedNodes_ = numberOfReleasedNodes; } /** * Returns the number of used nodes. * * @return The number of used nodes */ public int getNumberOfUsedNodes() { return numberOfUsedNodes_; } /** * Returns the number of migrations. * * @return The number of migrations */ public int getNumberOfMigrations() { return mapping_.size(); } /** * Returns the number of released nodes. * * @return The number of released nodes */ public int getNumberOfReleasedNodes() { return numberOfReleasedNodes_; } /** * Returns the mapping. * * @return The mapping */ public Map<VirtualMachineMetaData, LocalControllerDescription> getMapping() { return mapping_; } }