+sipb-xen-console-server (2) unstable; urgency=low
+
+ * Use a python based update-conserver script that gets the list of
+ consoles from xm list
+ * Run the update-conserver script every 5 minutes to catch VMs that
+ are not started or stopped through the remctl interface
+
+ -- Evan Broder <broder@sipb-xen-dev.mit.edu> Wed, 2 Apr 2008 04:32:58 -0400
+
sipb-xen-console-server (1.0.2) unstable; urgency=low
* Also...make this package actually do something
--- /dev/null
+#
+# cron-jobs for sipb-xen-console-server
+# Refresh the list of active VM consoles
+#
+
+MAILTO=root
+
+*/5 * * * * root python /usr/sbin/sipb-xen-update-conserver
-#!/bin/bash
+#!/usr/bin/python
-ls /etc/conserver/conf.d/ | sed -e 's|^|#include /etc/conserver/conf.d/|' >/etc/conserver/includes.cf
-/etc/init.d/conserver-server reload
\ No newline at end of file
+import sipb_xen_database
+import subprocess
+import os
+
+sipb_xen_database.connect('postgres://sipb-xen@sipb-xen-dev.mit.edu/sipb_xen')
+
+def live_vms():
+ p = subprocess.Popen(['xm', 'list'], stdout=subprocess.PIPE)
+ p.wait()
+ output = p.stdout.read()
+ vms = [x.split()[0][2:] for x in output.splitlines() if x.startswith('d_')]
+ return vms
+
+def reload_conserver():
+ p = subprocess.Popen(['/etc/init.d/conserver-server', 'restart'], stdout=subprocess.PIPE)
+ p.wait()
+
+if __name__ == '__main__':
+ f = open('/etc/conserver/sipb-xen-consoles.cf', 'w')
+ f.write('\n'.join('console %s {}' % vm for vm in live_vms()))
+ f.close()
+ reload_conserver()