上篇文章介绍了服务的注册和发现,那我们如何去消费服务呢?在SpringCloud中服务消费有两种方式,一种是ribbon+restTemplate的方式,也是本篇文章将要介绍的,另一种方式Fegin下篇文章会说到。

1、Ribbon简介
Ribbon是一个基于HTTP和TCP的负载均衡客户端,它基于Netflix Ribbon实现。通过Spring Cloud的封装,可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡的服务调用,Ribbon客户端组件可以提供一系列完善的配置选项,比如连接超时、重试、重试算法等。Ribbon内置可插拔、可定制的负载均衡组件。下面是用到的一些负载均衡策略:

简单轮询负载均衡 (默认)

加权响应时间负载均衡

区域感知轮询负载均衡

随机负载均衡

2、再注册一个实例

上篇文章中只在注册中心注册了一个实例,现在再注册一个实例(同一个服务),步骤为:

1、打开我们的eureka-client1项目,修改端口为:8002

2、这个勾去掉保存,启动,这时候注册中心就有两个实例了(同一个服务)

关闭 resttemplate 日志_ribbon


关闭 resttemplate 日志_ribbon_02


关闭 resttemplate 日志_ribbon_03


这时候再去看下注册中心,可以看到已经注册了两个实例

关闭 resttemplate 日志_ribbon_04


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();
    }
}

启动该项目

该消费者向注册中心注册了自己

关闭 resttemplate 日志_spring_05


4、测试接口

访问:http://localhost:8003/test/hello,多刷几次可以看到这两个结果再轮询打印,因为ribbon的负载均衡已经起了作用,默认是轮询模式

Hello world,this is eureka-client1--8001
Hello world,this is eureka-client1--8002