X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=modules%2Fbuildd%2Ffiles%2Fbuildd-schroot-aptitude-kill;h=fa7374642317a8f32bc59f9f57be7d5039cb87af;hb=d94208e70a3ca321373e1f4ba587afa82f919e8e;hp=07f75c1de2c7c4af8019469027c6d4cce99a5ca7;hpb=e3126d1408e005285d5cab06f4d7144461f43b11;p=mirror%2Fdsa-puppet.git diff --git a/modules/buildd/files/buildd-schroot-aptitude-kill b/modules/buildd/files/buildd-schroot-aptitude-kill index 07f75c1de..fa7374642 100755 --- a/modules/buildd/files/buildd-schroot-aptitude-kill +++ b/modules/buildd/files/buildd-schroot-aptitude-kill @@ -24,27 +24,39 @@ # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. import os -import psutil +import errno +import sys +try: + import psutil +except OSError, e: + # XXX: This is a hack, but since we are run from cron, it's + # better to handle this on the next run than to send mail. + if e.errno == errno.ENOENT: + sys.exit(0) total_mem = psutil.phymem_usage().total cutoff_time = 60*10 for p in psutil.process_iter(): try: - if p.name != 'aptitude': continue - parent = p.parent + if p.name() != 'aptitude': continue + parent = p.parent() if parent is None: continue - if parent.name != 'schroot': continue + if parent.name() != 'schroot': continue # - rootdir = os.readlink('/proc/%d/root'%(p.pid,)) + try: + rootdir = os.readlink('/proc/%d/root'%(p.pid,)) + except OSError as e: + if e.errno == errno.ENOENT: + continue + else: + raise e if not rootdir.startswith('/var/lib/schroot/mount'): continue # used = p.get_memory_info().vms - if used < total_mem: continue - # cputime = p.get_cpu_times().user - if cputime < cutoff_time: continue + if used < total_mem and cputime < cutoff_time: continue # p.kill() - except psutil.error.NoSuchProcess: + except psutil.NoSuchProcess: pass