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
<!--nacos服务注册发现-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
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);