« L'équilibrage de charge » peut être expliqué comme le maintien de n'importe quelle charge de travail. Par exemple, si vous devez servir 1000 petits-déjeuners le matin, vous pouvez diviser le travail entre 2-3 traiteurs ou plus pour réduire le délai de livraison/préparation.
Dans le monde informatique, la même logique s'applique, si vous souhaitez livrer rapidement, vous pouvez diviser le travail, par exemple pour un site Web, nous pouvons avoir 5 à 10 serveurs Web, de cette façon le site Web sera livré plus rapidement (surtout en cas de trafic élevé ), c'est côté serveur.
Je veux parler de l'équilibrage de charge côté client et de la façon dont cela fonctionne, par exemple, vous interrogez le backend pour chaque requête et vous avez plusieurs serveurs qui effectuent le travail backend, pour cela, j'utiliserai le service WHOIS
whois1.service.com whois2.service.com
Nous pouvons équilibrer la charge de chaque requête sur ces deux serveurs, l'algorithme le plus utilisé et le round robin par défaut, ce qui signifie que chaque requête ira à l'une plutôt qu'à l'autre, comme who1, who2 who1 et ainsi de suite, cela peut être fait côté client avec " Spring Cloud LoadBalancer ». nous devons configurer 3 classes
- ServiceInstanceListSupplier pour définir les adresses et les ports backend
- Bean ServiceInstanceListSupplier pour fournir la liste des points finaux
- @LoadBalancerClient qui est le client Web sera utilisé pour les appels backend
Maintenant, nous avons toute la configuration pour le backend
public class RestCaller implements ServiceInstanceListSupplier { private final String serviceId; public RestCaller(String serviceId) { this.serviceId = serviceId; } @Override public String getServiceId() { return serviceId; } @Override public Flux<list>> get() { return Flux.just(Arrays.asList( new DefaultServiceInstance(serviceId, serviceId, "abc.cyclic.app", 443, true), new DefaultServiceInstance(serviceId, serviceId, "someting.koyeb.app", 443, true), new DefaultServiceInstance(serviceId, serviceId, "127.0.0.1", 8080, false) )); } } @Configuration public class RestCallerConfiguration { @Autowired @Qualifier("webClientBuilder") WebClient.Builder webClientBuilder; @Bean @Primary ServiceInstanceListSupplier serviceInstanceListSupplier(ConfigurableApplicationContext ctx) { return ServiceInstanceListSupplier .builder() .withRetryAwareness() .withHealthChecks(webClientBuilder.build()) .withBase(new RestCaller("whoisService")) .build(ctx); } } @Configuration @LoadBalancerClient(name = "whoisService", configuration = RestCallerConfiguration.class) public class WebClientConfig { @LoadBalanced @Bean @Qualifier("loadBalancedWebClientBuilder") WebClient.Builder loadBalancedWebClientBuilder() { return WebClient.builder(); } @Bean @Qualifier("webClientBuilder") WebClient.Builder webClientBuilder() { return WebClient.builder(); } } </list>
Ceci peut désormais être utilisé dans n'importe quel @Component ou @Service.
@Component public class WhoisCaller { @Autowired @Qualifier("loadBalancedWebClientBuilder") WebClient.Builder webClientBuilder; public String getWhois(String ip, String source) { String url = "http://whoisService/whois?ip=" + ip + "&source=" + source; return webClientBuilder.build() .get() .uri(url) .retrieve() .bodyToMono(String.class) .timeout(Duration.ofMinutes(1)) .doOnError(e -> { WebClientResponseException e1 = (WebClientResponseException) e; log.error(e1.getRequest().getURI().getHost()); }) .block(); } }
Références :
- Ma question dans SO pour résoudre comment implémenter l'équilibrage de charge côté client avec Spring
- Spring Cloud LoadBalancer
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

Version Mac de WebStorm
Outils de développement JavaScript utiles

Dreamweaver Mac
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)