From 689eb2047d1a28f6e4044c96af78c44f16057196 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20Herv=C3=A9?= Date: Thu, 25 Feb 2021 09:30:07 +0100 Subject: [PATCH] Fix blocking connections in dogstatsd (#634) * Fix blocking connections in dogstatsd This adds back non blocking to UDP and sets non blocking before connect like it was before * Use lock on close, fix small issue in get_socket --- datadog/dogstatsd/base.py | 44 ++++++++++++++++++++------------------- 1 file changed, 23 insertions(+), 21 deletions(-) diff --git a/datadog/dogstatsd/base.py b/datadog/dogstatsd/base.py index 919cfdaaf..05002f163 100644 --- a/datadog/dogstatsd/base.py +++ b/datadog/dogstatsd/base.py @@ -307,25 +307,26 @@ def get_socket(self, telemetry=False): self.telemetry_socket = self._get_udp_socket_socket(self.telemetry_host, self.telemetry_port) return self.telemetry_socket - else: - if not self.socket: - if self.socket_path is not None: - self.socket = self._get_uds_socket(self.socket_path) - else: - self.socket = self._get_udp_socket(self.host, self.port) - return self.socket + if not self.socket: + if self.socket_path is not None: + self.socket = self._get_uds_socket(self.socket_path) + else: + self.socket = self._get_udp_socket(self.host, self.port) + + return self.socket @staticmethod def _get_uds_socket(socket_path): sock = socket.socket(socket.AF_UNIX, socket.SOCK_DGRAM) - sock.connect(socket_path) sock.setblocking(0) + sock.connect(socket_path) return sock @staticmethod def _get_udp_socket(host, port): sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) + sock.setblocking(0) sock.connect((host, port)) return sock @@ -492,19 +493,20 @@ def close_socket(self): """ Closes connected socket if connected. """ - if self.socket: - try: - self.socket.close() - except OSError as e: - log.error("Unexpected error: %s", str(e)) - self.socket = None - - if self.telemetry_socket: - try: - self.telemetry_socket.close() - except OSError as e: - log.error("Unexpected error: %s", str(e)) - self.telemetry_socket = None + with self.lock: + if self.socket: + try: + self.socket.close() + except OSError as e: + log.error("Unexpected error: %s", str(e)) + self.socket = None + + if self.telemetry_socket: + try: + self.telemetry_socket.close() + except OSError as e: + log.error("Unexpected error: %s", str(e)) + self.telemetry_socket = None def _serialize_metric(self, metric, metric_type, value, tags, sample_rate=1): # Create/format the metric packet