X-Git-Url: https://gerrit.akraino.org/r/gitweb?a=blobdiff_plain;f=cmdatahandlers%2Fsrc%2Fcmdatahandlers%2Fhosts%2Fconfig.py;h=65b188bf287ec2a54dac7a889735bfed0da19072;hb=refs%2Fchanges%2F73%2F1073%2F2;hp=e8bc78b691c23ba2c7be2fcd2820d65fdbaedf47;hpb=c389bdee7b3845b55f443dbf04c0ce4083a55886;p=ta%2Fconfig-manager.git diff --git a/cmdatahandlers/src/cmdatahandlers/hosts/config.py b/cmdatahandlers/src/cmdatahandlers/hosts/config.py index e8bc78b..65b188b 100644 --- a/cmdatahandlers/src/cmdatahandlers/hosts/config.py +++ b/cmdatahandlers/src/cmdatahandlers/hosts/config.py @@ -19,6 +19,10 @@ from cmdatahandlers.api import config from cmdatahandlers.api import utils from serviceprofiles import profiles +VNF_EMBEDDED_RESERVED_MEMORY = "512Mi" +DUAL_VIM_CONTROLLER_RESERVED_MEMORY = "64Gi" +DUAL_VIM_DEFAULT_RESERVED_MEMORY = "32Gi" +MIDDLEWARE_RESERVED_MEMORY = "12Gi" class Config(config.Config): def __init__(self, confman): @@ -808,8 +812,28 @@ class Config(config.Config): osd_disks = filter(lambda disk: disk.get('osd_disk', False), caas_disks) return map(lambda disk: _get_path_for_virtio_id(disk), osd_disks) + def get_system_reserved_memory(self, hostname): + caasconf = self.confman.get_caas_config_handler() + if caasconf.is_vnf_embedded_deployment(): + return VNF_EMBEDDED_RESERVED_MEMORY + + profiles = self.get_service_profiles(hostname) + if 'controller' in profiles: + return DUAL_VIM_CONTROLLER_RESERVED_MEMORY + if 'compute' in profiles: + return DUAL_VIM_DEFAULT_RESERVED_MEMORY + + return self.config.get(self.ROOT, {}).get('middleware_reserved_memory', + MIDDLEWARE_RESERVED_MEMORY) + + def set_default_reserved_memory_to_all_hosts(self, def_memory): + for host in self.get_hosts(): + self.config[self.ROOT][host]['middleware_reserved_memory'] = def_memory + def _get_path_for_virtio_id(disk): disk_id = disk.get('id', '') if disk_id: return "/dev/disk/by-id/virtio-{}".format(disk_id[:20]) + +