springcloud关于nacos实现服务的注册和发现

本文介绍了如何使用Nacos2.2.3作为服务注册中心,配合SpringBoot3.0.6和SpringCloud2022.0.1实现服务提供者和消费者。通过配置文件设置服务者和使用者,并利用@LoadBalanced的RestTemplate进行负载均衡调用。同时,展示了如何自定义NacosLoadBalancer策略,达到集群内的优先选择和服务发现。
摘要由CSDN通过智能技术生成

前言

使用最新版本技术栈实践

版本

JDK版本: Oracle OpenJDK version 19.0.2
nacos客户端: 2.2.3
SpringBoot: 3.0.6
SpringCloud: 2022.0.1
其他依赖:
依赖
SpringBoot和SpringCloud版本对应关系
SpringBoot和SpringCloud版本对应关系

具体实现

nacos客户端

单机启动命令

startup.cmd -m standalone

启动成功示意图

SpringBoot

提供服务者

application.yml of 提供服务者

spring:
  application:
    name: user-service
  cloud:
    nacos:
      server-addr: localhost:8848
      discovery:
        cluster-name: SH

使用服务者

application.yml of 使用服务者

spring:
  application:
    name: order-service
  cloud:
    nacos:
      server-addr: localhost:8848
      discovery:
        cluster-name: SH

在配置类中向容器注入RestTemplate的Bean

@Configuration
public class RestTemplateConfig {
    /**
     * 创建RestTemplate并注入spring容器
     **/
    @Bean
    @LoadBalanced
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

在配置类中注入负载均衡策略1(@Autowired有error没有关系,在启动类上使用@LoadBalancerClients的configuration 属性加载此配置类)

public class LoadBalancerConfig {
    @Autowired
    private NacosDiscoveryProperties nacos;

    /**
     * 负载均衡策略
     * RandomLoadBalancer 随机
     * RoundRobinLoadBalancer 轮询
     * NacosLoadBalancer 优先同集群,再随机
     **/
    @Bean
    ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,
                                                            LoadBalancerClientFactory loadBalancerClientFactory) {
        String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
//        return new RandomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);
//        return new RoundRobinLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);
        return new NacosLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name,nacos);
    }

启动类

@SpringBootApplication
@MapperScan("com.example.mapper")
@LoadBalancerClients(value = {
        @LoadBalancerClient(name = "user-service",configuration = LoadBalancerConfig.class),
})
public class OrderServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(OrderServiceApplication.class, args);
    }
}

结语

完成了基于nacos的集群优先的负载均衡策略的实现

其他:
nacos相对于eureka除了能够实现服务的注册和发现还有其他更多丰富功能,应用更广
使用ribbon有7种实现了IRule接口的负载均衡策略
springcloud 2020.0.x版本移除ribbon,springcloud推荐使用loadbalancer替换ribbon


  1. 在ReactorLoadBalancer接口类中通过CTRL+h查看其有三个实现类 ↩︎

  • 8
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值