forked from p15670423/monkey
Agent: Finish implementing threading/batching in `push_all_events_to_island`
This commit is contained in:
parent
e51a717bdf
commit
5542f67ceb
|
@ -1,5 +1,6 @@
|
||||||
import logging
|
import logging
|
||||||
import queue
|
import queue
|
||||||
|
import threading
|
||||||
|
|
||||||
import requests
|
import requests
|
||||||
|
|
||||||
|
@ -8,22 +9,27 @@ from pubsub import pub
|
||||||
|
|
||||||
from common.common_consts.timeouts import MEDIUM_REQUEST_TIMEOUT
|
from common.common_consts.timeouts import MEDIUM_REQUEST_TIMEOUT
|
||||||
from common.events import AbstractAgentEvent
|
from common.events import AbstractAgentEvent
|
||||||
|
from common.utils import Timer
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
DEFAULT_TIME_PERIOD = 5
|
||||||
|
WAKES_PER_PERIOD = 4
|
||||||
|
|
||||||
|
|
||||||
class push_all_events_to_island:
|
class push_all_events_to_island:
|
||||||
def __init__(self, server_address: str):
|
def __init__(self, server_address: str):
|
||||||
self._server_address = server_address
|
self._server_address = server_address
|
||||||
|
|
||||||
self._queue: queue.Queue[AbstractAgentEvent] = queue.Queue()
|
self._queue: queue.Queue[AbstractAgentEvent] = queue.Queue()
|
||||||
self._send_to_island_thread = self.batch_events_thread(self._queue, self._server_address)
|
|
||||||
|
|
||||||
|
self._send_to_island_thread = self.batch_events_thread(
|
||||||
|
self._queue, self._server_address, DEFAULT_TIME_PERIOD
|
||||||
|
)
|
||||||
self._send_to_island_thread.start()
|
self._send_to_island_thread.start()
|
||||||
|
|
||||||
def __call__(self, event: AbstractAgentEvent, topic=pub.AUTO_TOPIC):
|
def __call__(self, event: AbstractAgentEvent, topic=pub.AUTO_TOPIC):
|
||||||
topic_name = topic.getName()
|
topic_name = topic.getName()
|
||||||
|
|
||||||
self._queue.put(self._serialize_event(event, topic_name))
|
self._queue.put(self._serialize_event(event, topic_name))
|
||||||
|
|
||||||
logger.debug(f"Pushing event of type {topic_name} to the Island at {self._server_address}")
|
logger.debug(f"Pushing event of type {topic_name} to the Island at {self._server_address}")
|
||||||
|
@ -32,24 +38,66 @@ class push_all_events_to_island:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
class batch_events_thread:
|
class batch_events_thread:
|
||||||
def __init__(self, queue_of_events: queue.Queue, server_address: str):
|
def __init__(self, queue_of_events: queue.Queue, server_address: str, time_period: int):
|
||||||
self._queue = queue_of_events
|
self._queue = queue_of_events
|
||||||
self._server_address = server_address
|
self._server_address = server_address
|
||||||
|
self._time_period = time_period
|
||||||
|
|
||||||
|
self._event_batch = set()
|
||||||
|
self._should_run_batch_thread = True
|
||||||
|
|
||||||
def start(self):
|
def start(self):
|
||||||
pass
|
self._should_run_batch_thread = True
|
||||||
|
self._batch_events_thread = threading.Thread(
|
||||||
def _manage_next_event(self):
|
name="SendEventsToIslandInBatchesThread", target=self._manage_event_batches
|
||||||
pass
|
|
||||||
|
|
||||||
def _send_event_to_island(self, serialized_event):
|
|
||||||
requests.post( # noqa: DUO123
|
|
||||||
"https://%s/api/events" % (self._server_address,),
|
|
||||||
data=serialized_event,
|
|
||||||
headers={"content-type": "application/json"},
|
|
||||||
verify=False,
|
|
||||||
timeout=MEDIUM_REQUEST_TIMEOUT,
|
|
||||||
)
|
)
|
||||||
|
self._batch_events_thread.start()
|
||||||
|
|
||||||
|
def _manage_event_batches(self):
|
||||||
|
timer = Timer()
|
||||||
|
timer.set(self._time_period)
|
||||||
|
|
||||||
|
self._event_batch = {}
|
||||||
|
|
||||||
|
while self._should_run_batch_thread:
|
||||||
|
self._add_next_event_to_batch()
|
||||||
|
|
||||||
|
if timer.is_expired():
|
||||||
|
self._send_events_to_island()
|
||||||
|
timer.reset()
|
||||||
|
self._event_batch = {}
|
||||||
|
|
||||||
|
self._send_remaining_events()
|
||||||
|
|
||||||
|
def _add_next_event_to_batch(self):
|
||||||
|
try:
|
||||||
|
event = self._queue.get(block=True, timeout=self._time_period / WAKES_PER_PERIOD)
|
||||||
|
self._event_batch.add(event)
|
||||||
|
except queue.Empty:
|
||||||
|
pass
|
||||||
|
|
||||||
|
def _send_events_to_island(self):
|
||||||
|
for serialized_event in self._event_batch:
|
||||||
|
try:
|
||||||
|
requests.post( # noqa: DUO123
|
||||||
|
"https://%s/api/events" % (self._server_address,),
|
||||||
|
data=serialized_event,
|
||||||
|
headers={"content-type": "application/json"},
|
||||||
|
verify=False,
|
||||||
|
timeout=MEDIUM_REQUEST_TIMEOUT,
|
||||||
|
)
|
||||||
|
except Exception as exc:
|
||||||
|
logger.warning(
|
||||||
|
f"Exception caught when connecting to the Island at {self.server_address}"
|
||||||
|
f": {exc}"
|
||||||
|
)
|
||||||
|
|
||||||
|
def _send_remaining_events(self):
|
||||||
|
while not self._queue.empty():
|
||||||
|
self._add_next_event_to_batch()
|
||||||
|
|
||||||
|
self._send_events_to_island()
|
||||||
|
|
||||||
def stop(self):
|
def stop(self):
|
||||||
pass
|
self._should_run_batch_thread = False
|
||||||
|
self._batch_events_thread.join()
|
||||||
|
|
Loading…
Reference in New Issue