上篇文章介绍了服务的注册和发现,那我们如何去消费服务呢?在SpringCloud中服务消费有两种方式,一种是ribbon+restTemplate的方式,也是本篇文章将要介绍的,另一种方式Fegin下篇文章会说到。
1、Ribbon简介
Ribbon是一个基于HTTP和TCP的负载均衡客户端,它基于Netflix Ribbon实现。通过Spring Cloud的封装,可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡的服务调用,Ribbon客户端组件可以提供一系列完善的配置选项,比如连接超时、重试、重试算法等。Ribbon内置可插拔、可定制的负载均衡组件。下面是用到的一些负载均衡策略:
简单轮询负载均衡 (默认)
加权响应时间负载均衡
区域感知轮询负载均衡
随机负载均衡
2、再注册一个实例
上篇文章中只在注册中心注册了一个实例,现在再注册一个实例(同一个服务),步骤为:
1、打开我们的eureka-client1项目,修改端口为:8002
2、这个勾去掉保存,启动,这时候注册中心就有两个实例了(同一个服务)
这时候再去看下注册中心,可以看到已经注册了两个实例
3、创建一个消费者
不多废话,直接上代码了
pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>service-ribbon</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>service-ribbon</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
</repository>
</repositories>
</project>
application.yml,配置注册中心地址获取注册的实例,并且该消费者也会向注册中心注册自己
server:
port: 8003
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8000/eureka/
spring:
application:
name: service-ribbon
启动类上加注解@EnableDiscoveryClient,并向IOC容器中注册一个RestTemplate实例对象
@SpringBootApplication
@EnableDiscoveryClient
public class ServiceRibbonApplication {
public static void main(String[] args) {
SpringApplication.run(ServiceRibbonApplication.class, args);
}
@Bean
@LoadBalanced
RestTemplate restTemplate() {
return new RestTemplate();
}
}
写一个测试接口
/**
* @author XuJD
* @create 2019-11-22 16:02
**/
@Service
public class TestService {
@Autowired
private RestTemplate restTemplate;
public String testService(){
/*这个url就是上篇文章在注册中心注册的实例中的一个接口*/
return restTemplate.getForObject("http://eureka-client1/serviceTest/test",String.class);
}
}
/**
* @author XuJD
* @create 2019-11-22 16:01
**/
@RequestMapping("/test")
@RestController
public class TestController {
@Autowired
private TestService testService;
@RequestMapping("/hello")
public String hello(){
return testService.testService();
}
}
启动该项目
该消费者向注册中心注册了自己
4、测试接口
访问:http://localhost:8003/test/hello,多刷几次可以看到这两个结果再轮询打印,因为ribbon的负载均衡已经起了作用,默认是轮询模式
Hello world,this is eureka-client1--8001
Hello world,this is eureka-client1--8002