X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=src%2Femuvim%2Fdcemulator%2Fresourcemodel%2F__init__.py;h=3d05b966f67698917c0e6f421661f5e4ccb5b5f9;hb=644b319afbe785ecf05cad40dcbc118d57204c2d;hp=643236129b5b3393ca85e575619d0c7bea6aedab;hpb=a769d95a4ee55df7b12d93c10c71d29dff62cbeb;p=osm%2Fvim-emu.git diff --git a/src/emuvim/dcemulator/resourcemodel/__init__.py b/src/emuvim/dcemulator/resourcemodel/__init__.py index 6432361..3d05b96 100644 --- a/src/emuvim/dcemulator/resourcemodel/__init__.py +++ b/src/emuvim/dcemulator/resourcemodel/__init__.py @@ -8,6 +8,9 @@ LOG.setLevel(logging.DEBUG) class ResourceModelRegistrar(object): + """ + Global registry to keep track of all existing resource models. + """ def __init__(self, dc_emulation_max_cpu): self.e_cpu = dc_emulation_max_cpu @@ -16,20 +19,35 @@ class ResourceModelRegistrar(object): LOG.info("Resource model registrar created with dc_emulation_max_cpu=%r" % dc_emulation_max_cpu) def register(self, dc, rm): + """ + Register a new resource model. + :param dc: Data center to which it is assigned. + :param rm: The resource model object. + :return: None + """ if dc in self._resource_models: raise Exception("There is already an resource model assigned to this DC.") self._resource_models[dc] = rm rm.registrar = self + rm.dcs.append(dc) LOG.info("Registrar: Added resource model: %r" % rm) - @property - def num_models(self): - return len(self._resource_models) - @property def resource_models(self): + """ + List of registered resource models + :return: + """ return list(self._resource_models.itervalues()) + @property + def num_dcs_with_rms(self): + """ + Total number of data centers that are connected to a resource model + :return: + """ + return sum([len(rm.dcs) for rm in list(self._resource_models.itervalues())]) + class ResourceFlavor(object): """ @@ -52,16 +70,20 @@ class BaseResourceModel(object): """ def __init__(self): - self._flavors=dict() + self._flavors = dict() self._initDefaultFlavors() self.registrar = None # pointer to registrar + self.dcs = list() + self.allocated_compute_instances = dict() LOG.info("Resource model %r initialized" % self) def __repr__(self): return self.__class__.__name__ def _initDefaultFlavors(self): - # initialize some default flavours (inspired by OpenStack) + """ + initialize some default flavours (naming/sizes inspired by OpenStack) + """ self.addFlavour(ResourceFlavor( "tiny", {"compute": 1, "memory": 32, "disk": 1})) self.addFlavour(ResourceFlavor( @@ -91,6 +113,7 @@ class BaseResourceModel(object): :return: 3-tuple: (CPU-fraction, Mem-limit, Disk-limit) """ LOG.warning("Allocating in BaseResourceModel: %r with flavor: %r" % (name, flavor_name)) + self.allocated_compute_instances[name] = flavor_name return -1.0, -1.0, -1.0 # return invalid values to indicate that this RM is a dummy def free(self, name): @@ -100,4 +123,5 @@ class BaseResourceModel(object): :return: True/False """ LOG.warning("Free in BaseResourceModel: %r" % name) + del self.allocated_compute_instances[name] return True