Spring Cloud Ribbon实现客户端负载均衡的示例

时间:2022-09-22 20:40:21

前面我们已经完成了注册中心和服务提供者两个基础组件。本文就介绍使用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依赖

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<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,注册中心地址

?
1
2
3
spring.application.name=consumer
server.port=30001
eureka.client.service-url.defaultzone=http://localhost:10001/eureka/,http://localhost:10002/eureka/

编写usercontroller,添加@loadbalanced注解,启用ribbon负载均衡

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
@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,启用服务注册

?
1
2
3
4
5
6
7
@enableeurekaclient
@springbootapplication
public 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

?
1
2
3
spring.application.name=producer
server.port=20001
eureka.client.service-url.defaultzone=http://localhost:10001/eureka/,http://localhost:10002/eureka/

application-profile2.properties

?
1
2
3
spring.application.name=producer
server.port=20002
eureka.client.service-url.defaultzone=http://localhost:10001/eureka/,http://localhost:10002/eureka/

为了测试负载的效果,我们把被调用服务的端口打出来

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@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,启动两次,完成注册中心集群的服务启动。

Spring Cloud Ribbon实现客户端负载均衡的示例

启动服务提供者

按上面同样的方法,启动服务提供者。

启动服务消费者

服务提供者单机就可以了,正常启动consumerapplication即可。

验证

从浏览器输入http://localhost:30001/user/add

Spring Cloud Ribbon实现客户端负载均衡的示例

再次访问:

Spring Cloud Ribbon实现客户端负载均衡的示例

可以看到,我们的负载均衡调用服务,已经成功了,默认是按轮训的方式做负载均衡。

总结

本文介绍并完成了使用spring cloud ribbon进行客户端负载均衡的调用。

接下来我们继续介绍怎么使用spring cloud进行服务监控。

源码下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://www.majunwei.com/view/201710172307516562.html