2-1 Inicie nacos para realizar un equilibrio de carga personalizado para el descubrimiento de registros de servicios

Breve descripción de los puntos de memoria

1 nacos需要下载安装,手动启动
2 nacos通过配置文件中spring-name实现服务的注册
3 以下代码发现服务集群,通过服务实例ServiceInstance获取服务ip和端口
    List<ServiceInstance> instances = discoveryClient.getInstances("微服务名称");
4 这个步骤引入了一个自定义的负载均衡

Servicio de gestión de instalación y uso de nacos

Instalar nacos

  • Descargue y descomprima el paquete de instalación en formato zip
下载地址:https://github.com/alibaba/nacos/releases
  • Inicie nacos en el modo independiente predeterminado: startup.cmd -m standalone
  • Visite nacos: http: // localhost: 8848 / nacos

Utilice la función de registro del servicio nacos

  • 1 Agregar dependencia
        <!--nacos服务注册发现-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
  • 2 Agregar configuración
spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
  • 3 Agregue una anotación a la clase principal @EnableDiscoveryClient
  • Verificación: Verifique si el registro es exitoso en la lista de servicios de la consola de nacos
  • Introduzca el objeto DiscoveryClient en la clase 4 para lograr información de servicio remoto en el método
        // 根据微服务名称获取集群信息
        List<ServiceInstance> instances = discoveryClient.getInstances("service-product");
        // 随机数实现负载均衡,随机访问集群中某一个服务
        int random = new Random().nextInt(instances.size());
        ServiceInstance serviceInstance = instances.get(random);
        String host = serviceInstance.getHost();
        int port = serviceInstance.getPort();   
        // 拼接远程调用的服务地址
        String url = "http://" + host + ":" + port + "/product/" + pid;
        // 通过restTemplate远程调用对应服务
        Product product = restTemplate.getForObject(url, Product.class);
 = restTemplate.getForObject(url, Product.class);

Supongo que te gusta

Origin blog.csdn.net/weixin_45544465/article/details/105936533
Recomendado
Clasificación