From 5cbe16bb4364ecda8afb6b6e9c9dc40d77085a4a Mon Sep 17 00:00:00 2001 From: Kenjiro Nakayama Date: Sun, 7 Aug 2016 21:34:02 +0900 Subject: [PATCH] node-status outputs volumename instead of 0B utilization with non-physical volume --- command/node_status.go | 30 ++++++++++++++++++++++-------- 1 file changed, 22 insertions(+), 8 deletions(-) diff --git a/command/node_status.go b/command/node_status.go index 36e1ad4dfcb..e431a3353ec 100644 --- a/command/node_status.go +++ b/command/node_status.go @@ -480,22 +480,36 @@ func getHostResources(hostStats *api.HostStats, node *api.Node) ([]string, error // calculate disk usage storageDevice := node.Attributes["unique.storage.volume"] var diskUsed, diskSize uint64 + var physical bool for _, disk := range hostStats.DiskStats { if disk.Device == storageDevice { diskUsed = disk.Used diskSize = disk.Size + physical = true } } resources = make([]string, 2) resources[0] = "CPU|Memory|Disk" - resources[1] = fmt.Sprintf("%v/%v MHz|%v/%v|%v/%v", - math.Floor(hostStats.CPUTicksConsumed), - node.Resources.CPU, - humanize.IBytes(hostStats.Memory.Used), - humanize.IBytes(hostStats.Memory.Total), - humanize.IBytes(diskUsed), - humanize.IBytes(diskSize), - ) + if physical { + resources[1] = fmt.Sprintf("%v/%v MHz|%v/%v|%v/%v", + math.Floor(hostStats.CPUTicksConsumed), + node.Resources.CPU, + humanize.IBytes(hostStats.Memory.Used), + humanize.IBytes(hostStats.Memory.Total), + humanize.IBytes(diskUsed), + humanize.IBytes(diskSize), + ) + } else { + // If non-physical device are used, output device name only, + // since nomad doesn't collect the stats data. + resources[1] = fmt.Sprintf("%v/%v MHz|%v/%v|(%s)", + math.Floor(hostStats.CPUTicksConsumed), + node.Resources.CPU, + humanize.IBytes(hostStats.Memory.Used), + humanize.IBytes(hostStats.Memory.Total), + storageDevice, + ) + } return resources, nil }