X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=modules%2Fbuildd%2Ffiles%2Fbuildd-schroot-aptitude-kill;h=c7bc36a3a47ae2603ec48bf2e4e9be08041eb770;hb=54eade454bc9db2312ac374a94c79f6722333ce0;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..c7bc36a3a 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 +total_mem = psutil.virtual_memory().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