X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=src%2Femuvim%2Fdcemulator%2Fresourcemodel%2Fupb%2Fsimple.py;h=181bc9713a61d720e9b16976c3a75108683ab98d;hb=6a6d9a69d088b61d1bf0f2ea631d7d9f052013d3;hp=425d959d1e31e60445ef34c93003b760fda3a1e9;hpb=fed146dbb3d924fd67cf297956635e738318b7f4;p=osm%2Fvim-emu.git diff --git a/src/emuvim/dcemulator/resourcemodel/upb/simple.py b/src/emuvim/dcemulator/resourcemodel/upb/simple.py index 425d959..181bc97 100644 --- a/src/emuvim/dcemulator/resourcemodel/upb/simple.py +++ b/src/emuvim/dcemulator/resourcemodel/upb/simple.py @@ -35,6 +35,8 @@ class UpbSimpleCloudDcRM(BaseResourceModel): self.dc_alloc_mu = 0 self.deactivate_cpu_limit = deactivate_cpu_limit self.deactivate_mem_limit = deactivate_mem_limit + self.single_cu = 0 + self.single_mu = 0 super(self.__class__, self).__init__() def allocate(self, d): @@ -124,10 +126,8 @@ class UpbSimpleCloudDcRM(BaseResourceModel): :return: """ number_cu = self._get_flavor(d).get("compute") - # get cpu time fraction for entire emulation - e_cpu = self.registrar.e_cpu # calculate cpu time fraction of a single compute unit - single_cu = float(e_cpu) / sum([rm.dc_max_cu for rm in list(self.registrar.resource_models)]) + self.single_cu = self._compute_single_cu() # calculate cpu time fraction for container with given flavor cpu_time_percentage = self.single_cu * number_cu # calculate input values for CFS scheduler bandwidth limitation @@ -138,6 +138,16 @@ class UpbSimpleCloudDcRM(BaseResourceModel): d.name, cpu_period, cpu_time_percentage, cpu_quota)) d.updateCpuLimit(cpu_period=int(cpu_period), cpu_quota=int(cpu_quota)) + def _compute_single_cu(self): + """ + Calculate percentage of CPU time of a singe CU unit. + :return: + """ + # get cpu time fraction for entire emulation + e_cpu = self.registrar.e_cpu + # calculate + return float(e_cpu) / sum([rm.dc_max_cu for rm in list(self.registrar.resource_models)]) + def _calculate_cpu_cfs_values(self, cpu_time_percentage): """ Calculate cpu period and quota for CFS @@ -164,7 +174,7 @@ class UpbSimpleCloudDcRM(BaseResourceModel): # get memory amount for entire emulation e_mem = self.registrar.e_mem # calculate amount of memory for a single mu - single_mu = float(e_mem) / sum([rm.dc_max_mu for rm in list(self.registrar.resource_models)]) + self.single_mu = float(e_mem) / sum([rm.dc_max_mu for rm in list(self.registrar.resource_models)]) # calculate mem for given flavor mem_limit = self.single_mu * number_mu mem_limit = self._calculate_mem_limit_value(mem_limit) @@ -210,6 +220,8 @@ class UpbSimpleCloudDcRM(BaseResourceModel): r["dc_max_mu"] = self.dc_max_mu r["dc_alloc_cu"] = self.dc_alloc_cu r["dc_alloc_mu"] = self.dc_alloc_mu + r["single_cu_percentage"] = self.single_cu + r["single_mu_percentage"] = self.single_mu r["allocation_state"] = allocation_state return r