springcloud(10)-eureka-providrs集群-@LoadBalanced-默认负载均衡轮询策略

provider是多个的,consumer如何实现调用? eureka默认负载均衡方式是轮询 通过端口号来区分调用的。
1.写至少两个provider 8001,8002
2.Provider :Controller里的端口号从配置文件中读取,实现动态获取。
3.consumer:Controller里的端口也要写成变量,实现动态获取。
4.测试
5.没做负载均衡默认策略设置的易错项

 


1.写至少两个provider 8001,8002
2.Provider :Controller里的端口号从配置文件中读取,实现动态获取。

  2.1 在Controller中读取application.yml中的参数

server:
  port: 8001  #服务端口号
  @Value("${server.port}")
    private String serverPort;
//直接从application.yml中读取变量


3.consumer:Controller里的端口也要写成变量,实现动态获取。
   3.1Controller里的端口要写成变量的

访问的时候order80 port要写成变量,否则一直只访问一个端口
 

//OrderController  中的更改
public class OrderController {
  // public static final String PAYMENT_URL = "http://localhost:8001";

public static final String PAYMENT_URL = "http://CLOUD-PAYMENT-SERVICE";
}

3.2设置默认的负载均衡机制-轮询

方法:ApplicationContextConfig中加上@LoadBanced
 

@Configuration
public class ApplicationContextConfig
{
    @Bean
    @LoadBalanced  //使用注解赋予RestTemplate负载均衡的能力
    public RestTemplate getRestTemplate()
    {
        return new RestTemplate();
    }
}


4.测试
1.启动5个程序
2.eureka7001.com:7001

springcloud(10)-eureka-providrs集群-@LoadBalanced-默认负载均衡轮询策略_第1张图片

 payment-services 下应该有两个 8001 8002

3.eureka7002.com:7002 也应该有两个
 

springcloud(10)-eureka-providrs集群-@LoadBalanced-默认负载均衡轮询策略_第2张图片

4.访问

localhst:8001/payment/get/31
Localhst:8002/payment/get/31

Localhst/consumer/payment/get/31 80端口

刷新后,端口号一会8001,一会8002表示成功。
5.没做负载均衡默认策略设置的易错项
springcloud(10)-eureka-providrs集群-@LoadBalanced-默认负载均衡轮询策略_第3张图片

是因为没有配置@LoadBalanced,在consumer的RestTemplate上添加负载均衡机制。详见第3.2步。

你可能感兴趣的:(JAVA)