业务描述

一个服务实例可以处理请求是有限的,假如服务实例的并发访问比较大,我们会启动多个服务实例,让这些服务实例采用一定策略均衡(轮询,权重,随机,hash等)的处理并发请求,在Nacos中服务的负载均衡(Nacos客户端负载均衡)是如何应用的?

LoadBalancerClient应用
LoadBalancerClient对象可以从nacos中基于服务名获取服务实例,然后在工程中基于特点算法实现负载均衡方式的调用,案例实现如下:

第一步:修改ConsumerController类,注入LoadBalancerClient对象,并添加doRestEcho2方法,然后进行服务访问.
 

/*负载均衡客户端对象,基于对象可以获取nacos中的服务实例
    * 并且通过负载均衡算法从所有实例中*/
    @Autowired//可以在nacos中动态获取服务对象
    private LoadBalancerClient loadBalancerClient;
    @Value("${spring.application.name:sca-consumer}")
    private String appName;
    @GetMapping("/consumer/doRestEcho2")
    public String doRestEcho2 (){
        //从nacos获取服务实例(choose方法内置了负载均衡算法)
        ServiceInstance serviceInstance = loadBalancerClient.choose("sca-provider");//不负责服务调用,只负责获取服务实例
        String ip = serviceInstance.getHost();
        int port = serviceInstance.getPort();
        //String url="http://"+ip+":"+port+"/provider/echo/泥巴鼻+appName";
        String url =
                String.format("http://%s:%s/provider/echo/%s", ip, port, appName);//用来格式化字符串(%占位符%s字符串%d数字)
        return restTemplate.getForObject(url,String.class);
    }

第二步:打开Idea服务启动配置,如图所示:

nacos使用IP负载均衡策略_nacos使用IP负载均衡策略

第三步:修改并发运行选项(假如没有找到这个选项我们需要通过搜索引擎基于组合查询的方法,去找到对应的解决方案,例如搜索 idea allow parallel run),如图所示:

nacos使用IP负载均衡策略_java_02

第四步: 启动成功以后,访问nacos的服务列表,检测服务是否成功注册,如图所示:

 

nacos使用IP负载均衡策略_客户端_03

 

nacos使用IP负载均衡策略_java_04

 

nacos使用IP负载均衡策略_nacos使用IP负载均衡策略_05

 第六步:启动sca-consumer项目模块,打开浏览器对consumer服务进行访问,访问时不断刷新,检测页面数据变化。

说明,这里多个实例并发提供服务的方式为负载均衡,这里的负载均衡实现默认是因为Nacos集成了Ribbon来实现的,Ribbon配合RestTemplate,可以非常容易的实现服务之间的访问。Ribbon是Spring Cloud核心组件之一,它提供的最重要的功能就是客户端的负载均衡(客户端可以采用一定算法,例如轮询访问,访问服务端实例信息),这个功能可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡方式的服务调用。

RestTemplate在发送请求的时候会被LoadBalancerInterceptor拦截,它的作用就是用于RestTemplate的负载均衡,LoadBalancerInterceptor将负载均衡的核心逻辑交给了loadBalancer

Ribbon负载均衡策略(了解)

基于Ribbon方式的负载均衡,Netflix默认提供了七种负载均衡策略,对于SpringCloud Alibaba解决方案中又提供了NacosRule策略,默认的负载均衡策略是轮训策略。如图所示:

nacos使用IP负载均衡策略_nacos使用IP负载均衡策略_06

当系统提供的负载均衡策略不能满足我们需求时,我们还可以基于IRule接口自己定义策略. 

使用idea开启nacos的相关设置

nacos使用IP负载均衡策略_负载均衡_07

 

总结:

  • @Bean注解的作用?(一般用于配置类内部,描述相关方法,用于告诉spring此方法的返回值要交给spring管理,bean的名字默认为方法名,假如需要指定名字可以@Bean(“bean的名字”),最多的应用场景是整合第三方的资源-对象)
  • @Autowired注解的作用?(此注解用于描述属性,构造方法,set方法等,用于告诉spring框架,按找一定的规则为属性进行DI操作,默认按属性,方法参数类型查找对应的对象,假如只找到一个,则直接注入,类型多个时还会按照属性名或方法参数名进行值的注入,假如名字也不同,就出报错.)
  • Nacos中的负责均衡底层是如何实现的?(通过Ribbon实现,Ribbon中定义了一些负载均衡算法,然后基于这些算法从服务实例中获取一个实例为消费方法提供服务)
  • Ribbon 是什么?(Netflix公司提供的负载均衡客户端,一般应用于服务的消费方法)
  • Ribbon 可以解决什么问题? (基于负载均衡策略进行服务调用, 所有策略都会实现IRule接口)
  • Ribbon 内置的负载策略都有哪些?(8种,可以通过查看IRule接口的实现类进行分析)
  • @LoadBalanced的作用是什么?(描述RestTemplate对象,用于告诉Spring框架,在使用RestTempalte进行服务调用时,这个调用过程会被一个拦截器进行拦截,然后在拦截器内部,启动负载均衡策略。)
  • 我们可以自己定义负载均衡策略吗?(可以,基于IRule接口进行策略定义,也可以参考NacosRule进行实现)