From: Fredrik Tolf Date: Sat, 19 Jan 2013 00:17:49 +0000 (+0100) Subject: python: Properly abort when over request limit. X-Git-Tag: 0.12~6^3~1 X-Git-Url: http://git.dolda2000.com/gitweb/?a=commitdiff_plain;h=e0c88e73e0686a5fb12ec0e2a7303597a77fec30;p=ashd.git python: Properly abort when over request limit. --- diff --git a/python/ashd-wsgi b/python/ashd-wsgi index 807fe2b..01c158f 100755 --- a/python/ashd-wsgi +++ b/python/ashd-wsgi @@ -146,7 +146,7 @@ def mkenv(req): return env if reqlimit != 0: - guard = ashd.serve.calllimiter(reqlimit).call + guard = ashd.serve.abortlimiter(reqlimit).call else: guard = lambda fun: fun() diff --git a/python/ashd/serve.py b/python/ashd/serve.py index 4d5d9ca..14170d7 100644 --- a/python/ashd/serve.py +++ b/python/ashd/serve.py @@ -1,4 +1,4 @@ -import threading, time, logging +import os, threading, time, logging log = logging.getLogger("ashd.serve") seq = 1 @@ -125,3 +125,8 @@ class calllimiter(object): return target() finally: self.__exit__() + +class abortlimiter(calllimiter): + def waited(self, time): + if time > 10: + os.abort() diff --git a/python3/ashd-wsgi3 b/python3/ashd-wsgi3 index db54e6e..ba7038d 100755 --- a/python3/ashd-wsgi3 +++ b/python3/ashd-wsgi3 @@ -146,7 +146,7 @@ def mkenv(req): return env if reqlimit != 0: - guard = ashd.serve.calllimiter(reqlimit).call + guard = ashd.serve.abortlimiter(reqlimit).call else: guard = lambda fun: fun() diff --git a/python3/ashd/serve.py b/python3/ashd/serve.py index 9f9fe7f..fe839a2 100644 --- a/python3/ashd/serve.py +++ b/python3/ashd/serve.py @@ -1,4 +1,4 @@ -import threading, time, logging +import os, threading, time, logging log = logging.getLogger("ashd.serve") seq = 1 @@ -113,3 +113,8 @@ class calllimiter(object): def call(self, target): with self: return target() + +class abortlimiter(calllimiter): + def waited(self, time): + if time > 10: + os.abort()