org.cloudsimplus.brokers.VmCreation Maven / Gradle / Ivy
/*
* CloudSim Plus: A modern, highly-extensible and easier-to-use Framework for
* Modeling and Simulation of Cloud Computing Infrastructures and Services.
* http://cloudsimplus.org
*
* Copyright (C) 2015-2021 Universidade da Beira Interior (UBI, Portugal) and
* the Instituto Federal de Educação Ciência e Tecnologia do Tocantins (IFTO, Brazil).
*
* This file is part of CloudSim Plus.
*
* CloudSim Plus 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 3 of the License, or
* (at your option) any later version.
*
* CloudSim Plus 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 CloudSim Plus. If not, see .
*/
package org.cloudsimplus.brokers;
import lombok.AccessLevel;
import lombok.Getter;
import lombok.Setter;
import org.cloudsimplus.listeners.EventListener;
import org.cloudsimplus.vms.Vm;
/**
* Keeps track of number of VM creation requests and retries sent by a {@link DatacenterBroker}
* and enables configuring creation retries.
* VM creation fails when the broker can't find a suitable Host for placement.
*
* @author Manoel Campos da Silva Filho
* @author sohamchari
* @since CloudSim Plus 7.3.1
*/
@Getter @Setter
public class VmCreation {
/**
* Default number of times the broker will try to recreated failed VMs.
*/
public static final int DEF_CURRENT_VM_CREATION_RETRIES = 5;
/**
* A delay (in seconds) for the broker to retry allocating VMs
* that couldn't be placed due to lack of suitable active Hosts.
*
*
* - A value larger than zero indicates the broker will retry
* to place failed VM as soon as new VMs or Cloudlets
* are submitted or after the given delay.
* - otherwise, indicates failed VMs will be just added to the
* {@link DatacenterBroker#getVmFailedList()} and the user simulation have to deal with it.
* If the VM has an {@link Vm#addOnCreationFailureListener(EventListener) OnCreationFailureListener},
* it will be notified about the failure.
*
*/
private double retryDelay;
/**
* The maximum number of times the broker will try to find a host to create (place) the VM.
*/
private int maxRetries;
/**
* The current number of times failed VMs were tried to be recreated.
* @see #getMaxRetries()
*/
@Setter(AccessLevel.NONE)
private int retries;
/**
* The number of VM creation requests considering all submitted VMs.
*/
@Setter(AccessLevel.NONE)
private int creationRequests;
/**
* Creates an object with default values.
*/
public VmCreation() {
this.retryDelay = 5;
this.maxRetries = DEF_CURRENT_VM_CREATION_RETRIES;
}
/**
* Creates an object with the given values for the attributes.
* @param retryDelay a delay (in seconds) for the broker to retry allocating VMs
* that couldn't be placed due to lack of suitable active Hosts.
* @param maxRetries the maximum number of times the broker will try to find a host to create (place) the VM.
*/
public VmCreation(final double retryDelay, final int maxRetries) {
this.retryDelay = retryDelay;
this.maxRetries = maxRetries;
}
/**
* Creates an object with all attributes equal to zero.
* @return
*/
public static VmCreation ofZero(){
return new VmCreation(0, 0);
}
/**
* Checks if the broker has to retry allocating VMs
* that couldn't be placed due to lack of suitable Hosts.
* @return
*/
public boolean isRetryFailedVms() {
return retryDelay > 0 && retries < maxRetries;
}
/**
* Increments the current number of times failed VMs were tried to be recreated.
*/
public void incCurrentRetries() {
this.retries++;
}
/**
* Resets the number of VM creation requests to the {@link #DEF_CURRENT_VM_CREATION_RETRIES default number}.
*
* @see #incCurrentRetries()
*/
public void resetCurrentRetries() {
this.retries = DEF_CURRENT_VM_CREATION_RETRIES;
}
/**
* Increments/decrements the number of VM creation requests.
* @param value the value to increment/decrement
* @see #resetCurrentRetries()
*/
public void incCreationRequests(final int value) {
this.creationRequests += value;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy