Run each message handling logic on the bus on a separate thread to make sure that messages don't queue up too much
This commit is contained in:
parent
0e794cd1b0
commit
d5c31d938b
2 changed files with 15 additions and 6 deletions
|
@ -21,4 +21,8 @@ for route in get_routes():
|
||||||
app.register_blueprint(route)
|
app.register_blueprint(route)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
app.run()
|
||||||
|
|
||||||
|
|
||||||
# vim:sw=4:ts=4:et:
|
# vim:sw=4:ts=4:et:
|
||||||
|
|
|
@ -37,6 +37,16 @@ class Bus(object):
|
||||||
|
|
||||||
self.post(evt)
|
self.post(evt)
|
||||||
|
|
||||||
|
def _msg_executor(self, msg):
|
||||||
|
def executor():
|
||||||
|
try:
|
||||||
|
self.on_message(msg)
|
||||||
|
except Exception as e:
|
||||||
|
logger.error('Error on processing message {}'.format(msg))
|
||||||
|
logger.exception(e)
|
||||||
|
|
||||||
|
return executor
|
||||||
|
|
||||||
def poll(self):
|
def poll(self):
|
||||||
"""
|
"""
|
||||||
Reads messages from the bus until either stop event message or KeyboardInterrupt
|
Reads messages from the bus until either stop event message or KeyboardInterrupt
|
||||||
|
@ -54,11 +64,7 @@ class Bus(object):
|
||||||
.format(int(time.time()-msg.timestamp), msg))
|
.format(int(time.time()-msg.timestamp), msg))
|
||||||
continue
|
continue
|
||||||
|
|
||||||
try:
|
threading.Thread(target=self._msg_executor(msg)).start()
|
||||||
self.on_message(msg)
|
|
||||||
except Exception as e:
|
|
||||||
logger.error('Error on processing message {}'.format(msg))
|
|
||||||
logger.exception(e)
|
|
||||||
|
|
||||||
if isinstance(msg, StopEvent) and msg.targets_me():
|
if isinstance(msg, StopEvent) and msg.targets_me():
|
||||||
logger.info('Received STOP event on the bus')
|
logger.info('Received STOP event on the bus')
|
||||||
|
@ -66,4 +72,3 @@ class Bus(object):
|
||||||
|
|
||||||
|
|
||||||
# vim:sw=4:ts=4:et:
|
# vim:sw=4:ts=4:et:
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue