Log lock waits for task adding in WorkerManager
This commit is contained in:
parent
7ca09ba75b
commit
0881e274a9
2 changed files with 26 additions and 1 deletions
24
src/Debug/DebugLock.py
Normal file
24
src/Debug/DebugLock.py
Normal file
|
@ -0,0 +1,24 @@
|
|||
import time
|
||||
import logging
|
||||
|
||||
import gevent.lock
|
||||
|
||||
from Debug import Debug
|
||||
|
||||
|
||||
class DebugLock:
|
||||
def __init__(self, log_after=0.01, name="Lock"):
|
||||
self.name = name
|
||||
self.log_after = log_after
|
||||
self.lock = gevent.lock.Semaphore(1)
|
||||
self.release = self.lock.release
|
||||
|
||||
def acquire(self, *args, **kwargs):
|
||||
s = time.time()
|
||||
res = self.lock.acquire(*args, **kwargs)
|
||||
time_taken = time.time() - s
|
||||
if time_taken >= self.log_after:
|
||||
logging.debug("%s: Waited %.3fs after called by %s" %
|
||||
(self.name, time_taken, Debug.formatStack())
|
||||
)
|
||||
return res
|
Loading…
Add table
Add a link
Reference in a new issue