Spring Cloud 學習筆記04----服務消費者(RestTemplate+Ribbon(客戶端負載均衡))
簡介
上一篇《Spring Cloud 學習筆記02----服務治理》我們講到了服務的注冊與發(fā)現,在微服務框架中,我們將服務拆分成一個個獨立部署的子服務,這些服務通過http rest 來通訊的,Spring Cloud有兩種服務調用方式,一種是 RestTemplate+Ribbon, 另外一種是Feign 。
Ribbon 簡介
Ribbon 是一個基于HTTP和TCP的客戶端負載均衡工具。Feign默認集成了Ribbon。
Spring Cloud Netflix默認情況下為Ribbon(BeanType beanName:ClassName)提供以下bean
IClientConfig ribbonClientConfig:DefaultClientConfigImpl
IRule ribbonRule:ZoneAvoidanceRule
IPing ribbonPing:NoOpPing
ServerList ribbonServerList:ConfigurationBasedServerList
ServerListFilter ribbonServerListFilter:ZonePreferenceServerListFilter
ILoadBalancer ribbonLoadBalancer:ZoneAwareLoadBalancer
ServerListUpdater ribbonServerListUpdater:PollingServerListUpdater
準備工作
本示例的demo 是在我們上一個示例的基礎上擴展的。首先我們eureka-server 啟動,然后,啟動order-provider,端口號設置為2001,然后,在application.yml將端口號設置成2002,再啟動order-provider。
啟動成功之后我們可以在Eureka面板上看到ORDER-SERVICE注冊了兩個服務,相當于一個小集群。
建一個服務消費者
我們在新建一個spring boot 項目,將它命名為service-ribbon,
- 添加依賴
在pom文件中添加的依賴了spring-cloud-starter-netflix-eureka-client,spring-boot-starter-web,spring-cloud-start-ribbon的依賴
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.2.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.jay</groupId>
<artifactId>service-ribbon</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>service-ribbon</name>
<description>ribbon demo</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
</properties>
<dependencies>
<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-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-start-ribbon</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</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>
- 在
application.yml
文件中添加如下配置,配置了端口號,應用名,已經眾測中心地址。
server:
port: 8764
eureka:
client:
service-url:
# 用于指定注冊中心的地址
defaultZone: http://localhost:1111/eureka/
spring:
application:
name: service-ribbon
- 在啟動類
ServiceRibbonApplication
中添加如下注解。其中:@EnableEurekaClient
表示激活Eureka 中的DiscoveryClient 實現,其是基于spring-cloud-netflix依賴,只能為Eureka作用。(ps :如果注冊中心不為Eureka 的話,則推薦@EnableDiscoveryClient
,其是基于spring-cloud-commons依賴,并且在classpath中實現。)
并向IOC 容器中注入了一個RestTemplate的實例,通過@LoadBalanced
表示開啟負載均衡的功能。
@SpringBootApplication
@EnableEurekaClient
public class ServiceRibbonApplication {
public static void main(String[] args) {
SpringApplication.run(ServiceRibbonApplication.class, args);
}
@Bean
@LoadBalanced
RestTemplate restTemplate() {
return new RestTemplate();
}
}
- 我們新建一個HelloService 通過rest 的方式調用服務,通過服務名來調用服務,看看是否起到了負載均衡的功能。這里ribbon 會根據服務名來調用具體的服務實例,根據服務實例在請求時會將服務名替換成具體的url。代碼如下:
@Service
public class HelloService {
@Autowired
RestTemplate restTemplate;
public String getOrderService() {
return restTemplate.getForObject("http://ORDER-SERVICE/dc",String.class);
}
}
- 然后新建一個controller 測試下,服務的調用情況。
@RestController
public class HelloController {
@Autowired
private HelloService helloService;
@RequestMapping("/getOrderService")
public String getOrderService() {
return helloService.getOrderService();
}
}
測試結果如下:多次調用會交替顯示。
此時的架構
源碼地址:
https://github.com/XWxiaowei/SpringCloud-Learning/tree/master/2-Finchley版教程示例/Chapter4-1
參考:
史上最簡單的SpringCloud教程 | 第二篇: 服務消費者(rest+ribbon)
作者:碼農飛哥
微信公眾號:碼農飛哥