From ab4808fde127cf526fe6f463dd5e5ad0eccefc05 Mon Sep 17 00:00:00 2001 From: Olivier Levitt Date: Tue, 17 Dec 2024 16:32:21 +0100 Subject: [PATCH] Performance : mutualize kubernetes client (#537) --- .../kubernetes/KubernetesClientProvider.java | 28 +++++++++++++++++-- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/onyxia-api/src/main/java/fr/insee/onyxia/api/configuration/kubernetes/KubernetesClientProvider.java b/onyxia-api/src/main/java/fr/insee/onyxia/api/configuration/kubernetes/KubernetesClientProvider.java index 42cbaabd..085cc8b7 100644 --- a/onyxia-api/src/main/java/fr/insee/onyxia/api/configuration/kubernetes/KubernetesClientProvider.java +++ b/onyxia-api/src/main/java/fr/insee/onyxia/api/configuration/kubernetes/KubernetesClientProvider.java @@ -6,6 +6,8 @@ import io.fabric8.kubernetes.client.ConfigBuilder; import io.fabric8.kubernetes.client.KubernetesClient; import io.fabric8.kubernetes.client.KubernetesClientBuilder; +import java.util.HashMap; +import java.util.Map; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -16,6 +18,10 @@ public class KubernetesClientProvider { private static final Logger LOGGER = LoggerFactory.getLogger(KubernetesClientProvider.class); + private static Map rootKubernetesClientCache = new HashMap<>(); + + private static KubernetesClient userKubernetesClientCache = null; + /** * This returns the root client which has extended permissions. Currently cluster-admin. User * calls should be done using the userClient which only has user permissions. @@ -23,12 +29,28 @@ public class KubernetesClientProvider { * @param region * @return */ - public KubernetesClient getRootClient(Region region) { - final Config config = getDefaultConfiguration(region).build(); - return new KubernetesClientBuilder().withConfig(config).build(); + public synchronized KubernetesClient getRootClient(Region region) { + if (!rootKubernetesClientCache.containsKey(region.getId())) { + final Config config = getDefaultConfiguration(region).build(); + rootKubernetesClientCache.put( + region.getId(), new KubernetesClientBuilder().withConfig(config).build()); + } + return rootKubernetesClientCache.get(region.getId()); } public KubernetesClient getUserClient(Region region, User user) { + // In case of SERVICEACCOUNT authentication, we can safely mutualize and use a single + // KubernetesClient + if (region.getServices().getAuthenticationMode() + == Region.Services.AuthenticationMode.SERVICEACCOUNT) { + if (userKubernetesClientCache != null) { + return userKubernetesClientCache; + } + Config config = getDefaultConfiguration(region).build(); + KubernetesClient client = new KubernetesClientBuilder().withConfig(config).build(); + userKubernetesClientCache = client; + return client; + } final Config config = getDefaultConfiguration(region).build(); String username = user.getIdep(); if (region.getServices().getUsernamePrefix() != null) {