时间:2021-05-20
前面我们已经完成了注册中心和服务提供者两个基础组件。本文就介绍使用Spring Cloud Ribbon在客户端负载均衡的调用服务。
对于大型应用系统负载均衡(LB:Load Balancing)是首要被解决一个问题。在微服务之前LB方案主要是集中式负载均衡方案,在服务消费者和服务提供者之间又一个独立的LB,LB通常是专门的硬件,如F5,或者是基于软件的,如VS、HAproxy等。LB上有所有服务的地址映射表,当服务消费者调用某个目标服务时,它先向LB发起请求,由LB以某种策略(比如:Round-Robin)做负载均衡后将请求转发到目标服务。
而微服务的出现,则为LB的实现提供了另外一种思路:把LB的功能以库的方式集成到服务消费方的进程内,而不是由一个集中的设备或服务器提供。这种方案称为软负载均衡(Soft Load Balancing)或者客户端负载均衡。在Spring Cloud中配合Eureka的服务注册功能,Ribbon子项目则为REST客户端实现了负载均衡。
使用Spring Cloud Ribbon实现服务消费者
新建spring-cloud-sample-tutorial-consumer项目
在spring-cloud-sample-tutorial下新建spring-cloud-sample-tutorial-consumer子项目
添加ribbon和eureka依赖
<dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-ribbon</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency></dependencies>配置applicatioin.properties,注册中心地址
spring.application.name=consumerserver.port=30001eureka.client.service-url.defaultZone=http://localhost:10001/eureka/,http://localhost:10002/eureka/编写UserController,添加@LoadBalanced注解,启用Ribbon负载均衡
@Controller@RequestMapping("user")public class UserController { @Bean @LoadBalanced RestTemplate initRestTemplate(){ return new RestTemplate(); } @Autowired private RestTemplate restTemplate; @RequestMapping("add") @ResponseBody public String add(String userName, String age){ return restTemplate.getForEntity("http://PRODUCER/user/add",String.class,userName,age).getBody(); }}编写ConsumerApplication,添加@EnableEurekaClient,启用服务注册
@EnableEurekaClient@SpringBootApplicationpublic class ConsumerApplication { public static void main(String[] args) { SpringApplication.run(ConsumerApplication.class,args); }}集群部署Producer
为了模拟集群的Producer,在producer项目中新建application-profile1.properties和application-profile2.properties。
application-profile1.properties
spring.application.name=producerserver.port=20001eureka.client.service-url.defaultZone=http://localhost:10001/eureka/,http://localhost:10002/eureka/application-profile2.properties
spring.application.name=producerserver.port=20002eureka.client.service-url.defaultZone=http://localhost:10001/eureka/,http://localhost:10002/eureka/为了测试负载的效果,我们把被调用服务的端口打出来
@Controller@RequestMapping("user")public class UserController { private Logger logger = LoggerFactory.getLogger(getClass()); @Autowired private DiscoveryClient client; @RequestMapping("add") @ResponseBody public String addUser(String userName, String age) { return "Success from " + client.getLocalServiceInstance().getHost() + ":" + client.getLocalServiceInstance().getPort() ; }}启动测试
启动注册中心
分别配置Active Profiles为profile1和profile2,启动两次,完成注册中心集群的服务启动。
启动服务提供者
按上面同样的方法,启动服务提供者。
启动服务消费者
服务提供者单机就可以了,正常启动ConsumerApplication即可。
验证
从浏览器输入http://localhost:30001/user/add
再次访问:
可以看到,我们的负载均衡调用服务,已经成功了,默认是按轮训的方式做负载均衡。
总结
本文介绍并完成了使用Spring Cloud Ribbon进行客户端负载均衡的调用。
接下来我们继续介绍怎么使用Spring Cloud进行服务监控。
源码下载
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
概述SpringCloud中,客户端的负载均衡使用的是Ribbon,Ribbon的超时时间默认很短,需要进行调整。SpringCloud版本Edgware.SR
简介我们继续以之前博客的代码为基础,增加ribbon组件来提供客户端负载均衡。负载均衡是实现高并发、高性能、可伸缩服务的重要组成部分,它可以把请求分散到一个集群
前言前面我们学习了SpringCloud整合Consul,在此基础上我们手写本地客户端实现类似Ribbon负载均衡的效果。注:order模块调用者记得关闭@Lo
1.1简介1.1.1概述  Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP客户端的行为。为Ribbon配置服
前言Ribbon是一个客户端负载均衡器,它提供了对HTTP和TCP客户端的行为的大量控制。我们在上篇(猛戳:SpringCloud系列——Feign服务调用)已