Add option to return disk usage report with byte suffix.
Disk usage is currently returned as bytes. This patch adds the option to return the value with a more human-friendly suffix, eg. MB/GB/TB/PB. Change-Id: I3d55181f7e6085e711bd6e09ea2ce0a12b290cc5
This commit is contained in:
parent
645d1c93c5
commit
33706cb974
@ -47,6 +47,15 @@ def seconds2timeunit(seconds):
|
|||||||
return elapsed, unit
|
return elapsed, unit
|
||||||
|
|
||||||
|
|
||||||
|
def size_suffix(size):
|
||||||
|
suffixes = ['bytes', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']
|
||||||
|
for suffix in suffixes:
|
||||||
|
if size < 1000:
|
||||||
|
return "%s %s" % (size, suffix)
|
||||||
|
size = size / 1000
|
||||||
|
return "%s %s" % (size, suffix)
|
||||||
|
|
||||||
|
|
||||||
class Scout(object):
|
class Scout(object):
|
||||||
"""
|
"""
|
||||||
Obtain swift recon information
|
Obtain swift recon information
|
||||||
@ -625,7 +634,7 @@ class SwiftRecon(object):
|
|||||||
print "No hosts returned valid data."
|
print "No hosts returned valid data."
|
||||||
print "=" * 79
|
print "=" * 79
|
||||||
|
|
||||||
def disk_usage(self, hosts, top=0):
|
def disk_usage(self, hosts, top=0, human_readable=False):
|
||||||
"""
|
"""
|
||||||
Obtain and print disk usage statistics
|
Obtain and print disk usage statistics
|
||||||
|
|
||||||
@ -686,6 +695,10 @@ class SwiftRecon(object):
|
|||||||
raw_avail = sum(raw_total_avail)
|
raw_avail = sum(raw_total_avail)
|
||||||
raw_total = raw_used + raw_avail
|
raw_total = raw_used + raw_avail
|
||||||
avg_used = 100.0 * raw_used / raw_total
|
avg_used = 100.0 * raw_used / raw_total
|
||||||
|
if human_readable:
|
||||||
|
raw_used = size_suffix(raw_used)
|
||||||
|
raw_avail = size_suffix(raw_avail)
|
||||||
|
raw_total = size_suffix(raw_total)
|
||||||
print "Disk usage: space used: %s of %s" % (raw_used, raw_total)
|
print "Disk usage: space used: %s of %s" % (raw_used, raw_total)
|
||||||
print "Disk usage: space free: %s of %s" % (raw_avail, raw_total)
|
print "Disk usage: space free: %s of %s" % (raw_avail, raw_total)
|
||||||
print "Disk usage: lowest: %s%%, highest: %s%%, avg: %s%%" % \
|
print "Disk usage: lowest: %s%%, highest: %s%%, avg: %s%%" % \
|
||||||
@ -709,6 +722,7 @@ class SwiftRecon(object):
|
|||||||
usage = '''
|
usage = '''
|
||||||
usage: %prog <server_type> [-v] [--suppress] [-a] [-r] [-u] [-d]
|
usage: %prog <server_type> [-v] [--suppress] [-a] [-r] [-u] [-d]
|
||||||
[-l] [--md5] [--auditor] [--updater] [--expirer] [--sockstat]
|
[-l] [--md5] [--auditor] [--updater] [--expirer] [--sockstat]
|
||||||
|
[--human-readable]
|
||||||
|
|
||||||
<server_type>\taccount|container|object
|
<server_type>\taccount|container|object
|
||||||
Defaults to object server.
|
Defaults to object server.
|
||||||
@ -734,6 +748,8 @@ class SwiftRecon(object):
|
|||||||
help="Check cluster for unmounted devices")
|
help="Check cluster for unmounted devices")
|
||||||
args.add_option('--diskusage', '-d', action="store_true",
|
args.add_option('--diskusage', '-d', action="store_true",
|
||||||
help="Get disk usage stats")
|
help="Get disk usage stats")
|
||||||
|
args.add_option('--human-readable', action="store_true",
|
||||||
|
help="Use human readable suffix for disk usage stats")
|
||||||
args.add_option('--loadstats', '-l', action="store_true",
|
args.add_option('--loadstats', '-l', action="store_true",
|
||||||
help="Get cluster load average stats")
|
help="Get cluster load average stats")
|
||||||
args.add_option('--quarantined', '-q', action="store_true",
|
args.add_option('--quarantined', '-q', action="store_true",
|
||||||
@ -836,7 +852,7 @@ class SwiftRecon(object):
|
|||||||
if options.loadstats:
|
if options.loadstats:
|
||||||
self.load_check(hosts)
|
self.load_check(hosts)
|
||||||
if options.diskusage:
|
if options.diskusage:
|
||||||
self.disk_usage(hosts, options.top)
|
self.disk_usage(hosts, options.top, options.human_readable)
|
||||||
if options.md5:
|
if options.md5:
|
||||||
self.get_ringmd5(hosts, ring_file)
|
self.get_ringmd5(hosts, ring_file)
|
||||||
if options.quarantined:
|
if options.quarantined:
|
||||||
|
Loading…
Reference in New Issue
Block a user