Skip to content

Commit

Permalink
Host-Api: Create summary over all nodes
Browse files Browse the repository at this point in the history
The code assumes that there is a single compute-node per host,
which is incorrect for ironic. By summarising over all hosts,
we get a correct response also for compute-hosts with more than
one compute-node.

Change-Id: Iaf6e2a72f6649e234660de47bec8b1da1ea1571e
  • Loading branch information
fwiesel committed Mar 8, 2022
1 parent 18fda98 commit ff5009b
Showing 1 changed file with 18 additions and 13 deletions.
31 changes: 18 additions & 13 deletions nova/api/openstack/compute/hosts.py
Original file line number Diff line number Diff line change
Expand Up @@ -204,20 +204,26 @@ def reboot(self, req, id):
return self._host_power_action(req, host_name=id, action="reboot")

@staticmethod
def _get_total_resources(host_name, compute_node):
def _get_total_resources(host_name, compute_nodes):
return {'resource': {'host': host_name,
'project': '(total)',
'cpu': compute_node.vcpus,
'memory_mb': compute_node.memory_mb,
'disk_gb': compute_node.local_gb}}
'cpu': sum(cn.vcpus
for cn in compute_nodes),
'memory_mb': sum(cn.memory_mb
for cn in compute_nodes),
'disk_gb': sum(cn.local_gb
for cn in compute_nodes)}}

@staticmethod
def _get_used_now_resources(host_name, compute_node):
def _get_used_now_resources(host_name, compute_nodes):
return {'resource': {'host': host_name,
'project': '(used_now)',
'cpu': compute_node.vcpus_used,
'memory_mb': compute_node.memory_mb_used,
'disk_gb': compute_node.local_gb_used}}
'cpu': sum(cn.vcpus_used
for cn in compute_nodes),
'memory_mb': sum(cn.memory_mb_used
for cn in compute_nodes),
'disk_gb': sum(cn.local_gb_used
for cn in compute_nodes)}}

@staticmethod
def _get_resource_totals_from_instances(host_name, instances):
Expand Down Expand Up @@ -271,16 +277,15 @@ def show(self, req, id):
try:
mapping = objects.HostMapping.get_by_host(context, host_name)
nova_context.set_target_cell(context, mapping.cell_mapping)
compute_node = (
objects.ComputeNode.get_first_node_by_host_for_old_compat(
context, host_name))
compute_nodes = objects.ComputeNodeList.get_all_by_host(
context, host_name)
instances = self.api.instance_get_all_by_host(context, host_name)
except (exception.ComputeHostNotFound,
exception.HostMappingNotFound) as e:
raise webob.exc.HTTPNotFound(explanation=e.format_message())
resources = [self._get_total_resources(host_name, compute_node)]
resources = [self._get_total_resources(host_name, compute_nodes)]
resources.append(self._get_used_now_resources(host_name,
compute_node))
compute_nodes))
resources.append(self._get_resource_totals_from_instances(host_name,
instances))
by_proj_resources = self._get_resources_by_project(host_name,
Expand Down

0 comments on commit ff5009b

Please sign in to comment.