在上一篇文章,讲了服务的注册和发现。在微服务架构中,业务都会被拆分成一个独立的服务,服务与服务的通讯是基于http restful的。Spring cloud有两种服务调用方式,一种是ribbon+restTemplate,另一种是feign。在这一篇文章首先讲解下基于ribbon+rest。
ribbon是一个负载均衡客户端,可以很好的控制htt和tcp的一些行为。
1.准备工作
继上篇文章的项目,新建两个服务,user9000,user9002,两个服务都做负载均衡ribbon。
1.1 创建项目
和之前一样,但是这里选择ribbon
1.2 “三板斧”
a.pom文件
<?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>com.jason</groupId>
<artifactId>jason-cloud</artifactId>
<version>1.0-SNAPSHOT</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.jason</groupId>
<artifactId>consumer-user</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>consumer-user</name>
<description>Spring Cloud Eureka 消费端 User</description>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.0.0</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.17</version>
<scope>runtime</scope>
</dependency>
<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>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.6</version>
<scope>provided</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>
</project>
b.配置
server.port=9000
#注册到eureka服务端的微服务名称
spring.application.name=consumer-user
#注册到eureka服务端的地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
#eureka.client.service-url.defaultZone: http://www.eureka9000.com:9000/eureka/
#点击具体的微服务,右下角是否显示ip
eureka.instance.prefer-ip-address=true
#显示微服务的名称
eureka.instance.instance-id=consumer-user-9000
mybatis.configuration.map-underscore-to-camel-case=true
#配置数据库
spring.datasource.url=jdbc:mysql://localhost:3306/jason-cloud?serverTimezone=GMT&useUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=admin
logging.level.com.jason.consumeruser.dao=debug
另外一个一样,修改端口和服务名称
server.port=9002
#注册到eureka服务端的微服务名称
spring.application.name=consumer-user
#注册到eureka服务端的地址
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
#eureka.client.service-url.defaultZone: http://www.eureka9000.com:9000/eureka/
#点击具体的微服务,右下角是否显示ip
eureka.instance.prefer-ip-address=true
#显示微服务的名称
eureka.instance.instance-id=consumer-user-9002
mybatis.configuration.map-underscore-to-camel-case=true
#配置数据库
spring.datasource.url=jdbc:mysql://localhost:3306/jason-cloud?serverTimezone=GMT&useUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=admin
logging.level.com.jason.consumeruser.dao=debug
c.贴注解
项目结构:
2.创建配置类,向程序的ioc注入一个bean: restTemplate;并通过@LoadBalanced注解表明这个restRemplate开启负载均衡的功能。
2.1 写接口,通过之前注入ioc容器的restTemplate来消费CONSUMER-USER服务的“/user/log-user-instance”接口,在这里我们直接用的程序名替代了具体的url地址,在ribbon中它会根据服务名来选择具体的服务实例,根据服务实例在请求的时候会用具体的url替换掉服务名,代码如下:
@GetMapping("/log-user-instance")
public String logUserInstance() {
ServiceInstance serviceInstance = loadBalancerClient.choose("CONSUMER-USER");
log.info("serviceId------------>:{},ip:{},port:{}",serviceInstance.getServiceId(),serviceInstance.getHost(),serviceInstance.getPort());
return serviceInstance.getServiceId()+serviceInstance.getHost()+serviceInstance.getPort();
}
3.启动服务
3.1 访问接口,/user/log-user-instance,ribbon负载均衡默认轮询策略。下面发现多次访问返回值的ip是9000,9002轮流来。
4.此时的结构
一个服务注册中心,eureka server,端口为8761
CONSUMER-USER 工程跑了两个实例,端口分别为9000,9002,分别向服务注册中心注册
当通过restTemplate调用 CONSUMER-USER 的/user/log-user-instance接口时,因为用ribbon进行了负载均衡,会轮流的调用CONSUMER-USER:9000和9002 两个端口的/user/log-user-instance接口;