summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
220b27c)
svn path=/trunk/packages/invirt-remote/; revision=2107
invirt-remote (0.3.3) unstable; urgency=low
* added remctl web availability to calculate memory available to new VMs
invirt-remote (0.3.3) unstable; urgency=low
* added remctl web availability to calculate memory available to new VMs
+ * removed remctl web info
- -- Peter A. Iannucci <iannucci@mit.edu> Thu, 12 Feb 2009 23:10:31 -0500
+ -- Peter A. Iannucci <iannucci@mit.edu> Thu, 12 Feb 2009 23:26:24 -0500
invirt-remote (0.3.2) unstable; urgency=low
invirt-remote (0.3.2) unstable; urgency=low
return int(num) * {'kb':1, 'mb':1024}[unit.lower()]
def main(argv):
return int(num) * {'kb':1, 'mb':1024}[unit.lower()]
def main(argv):
+ """
+ Calculate the amount of memory available for new VMs
+ The numbers returned by xm info and xm info -c are in MB
+ The numbers in /proc/xen/balloon have nice units
+ All math is done in kilobytes for consistency
+ Output is in MB
+ """
p = Popen(['/usr/sbin/xm', 'info'], stdout=PIPE)
output = p.communicate()[0]
if p.returncode != 0:
raise RuntimeError("Command '%s' returned non-zero exit status %d"
p = Popen(['/usr/sbin/xm', 'info'], stdout=PIPE)
output = p.communicate()[0]
if p.returncode != 0:
raise RuntimeError("Command '%s' returned non-zero exit status %d"
- % ('invirt-availability', p.returncode))
+ % ('/usr/sbin/xm info', p.returncode))
xminfo = yaml.load(output, yaml.CSafeLoader)
xminfo = yaml.load(output, yaml.CSafeLoader)
free_memory = int(xminfo['free_memory']) * 1024
free_memory = int(xminfo['free_memory']) * 1024
- f = open('/proc/xen/balloon', 'r')
- ballooninfo = yaml.load(f.read())
- f.close()
+ ballooninfo = yaml.load(open('/proc/xen/balloon', 'r').read())
currentallocation = parseUnits(ballooninfo['Current allocation'])
minimumtarget = parseUnits(ballooninfo['Minimum target'])
currentallocation = parseUnits(ballooninfo['Current allocation'])
minimumtarget = parseUnits(ballooninfo['Minimum target'])
output = p.communicate()[0]
if p.returncode != 0:
raise RuntimeError("Command '%s' returned non-zero exit status %d"
output = p.communicate()[0]
if p.returncode != 0:
raise RuntimeError("Command '%s' returned non-zero exit status %d"
- % ('invirt-availability', p.returncode))
+ % ('/usr/sbin/xm info -c', p.returncode))
xminfoc = yaml.load(output, yaml.CSafeLoader)
# In kilobytes
xminfoc = yaml.load(output, yaml.CSafeLoader)
# In kilobytes
control)
# $SERVICE is hostname
COMMAND=/usr/sbin/invirt-vmcontrol
control)
# $SERVICE is hostname
COMMAND=/usr/sbin/invirt-vmcontrol
web)
case "$SERVICE" in
lvcreate|lvremove|lvrename|lvresize)
COMMAND=/usr/sbin/invirt-lvm
web)
case "$SERVICE" in
lvcreate|lvremove|lvrename|lvresize)
COMMAND=/usr/sbin/invirt-lvm
listvms)
COMMAND=/usr/sbin/invirt-listvms
listvms)
COMMAND=/usr/sbin/invirt-listvms
- ;;
- info)
- COMMAND=/usr/sbin/xm
;;
availability)
COMMAND=/usr/sbin/invirt-availability
;;
availability)
COMMAND=/usr/sbin/invirt-availability
*)
echo "ERROR: invalid command"
exit 34
*)
echo "ERROR: invalid command"
exit 34