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

 payment-services 下应该有两个 8001 8002

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

4.访问

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

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

刷新后,端口号一会8001,一会8002表示成功。
5.没做负载均衡默认策略设置的易错项

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值