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步。