javascript
Spring Cloud —— Feign 实现服务调用
引言
本篇博客簡單介紹 Feign 的基礎(chǔ)知識和基本應(yīng)用,以前一篇博客《Spring Cloud Alibaba——Nacos實現(xiàn)服務(wù)治理》為代碼基礎(chǔ),實現(xiàn)更簡單的微服務(wù)調(diào)用方式。
一、什么是Feign
restTemplate 實現(xiàn)的微服務(wù)調(diào)用方式:
// 調(diào)用商品微服務(wù),查詢商品信息 Product prod = restTemplate.getForObject("http://" + prodService.getHost() + ":" + prodService.getPort() + "/product/" + pid, Product.class);依然存在一些不盡如人意的地方:
1、代碼可讀性不好
2、編碼風(fēng)格不統(tǒng)一。調(diào)用本地服務(wù)使用 @Autowired 注入的方式,而調(diào)用遠程的服務(wù)是使用 restTemplate 調(diào)用。
基于以上兩點問題,就出現(xiàn)了新的 Spring Cloud 組件 —— Feign。
Feign 是 Spring Cloud 提供的一個聲明式偽 HTTP 客戶端。它使得調(diào)用遠程服務(wù)就像調(diào)用本地服務(wù)一樣優(yōu)雅,只需要創(chuàng)建一個接口并添加一個注解即可。
Nacos 很好的兼容了 Feign ,Feign 默認(rèn)集成了 Ribbon,所以在 Nacos 下使用 Feign 默認(rèn)就實現(xiàn)了負載均衡的效果。
二、Feign 的使用
微服務(wù)調(diào)用關(guān)系圖:
上圖中微服務(wù)調(diào)用關(guān)系是 通過 訂單微服務(wù) 調(diào)用 商品微服務(wù) 查詢商品信息,因此關(guān)于 Feign 的相關(guān)編碼也都是在 shop-order 微服務(wù)上。
1、添加 Feign 依賴
<!--Feign--> <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>2、在主類上添加 @EnableFeignClients 注解
@EnableDiscoveryClient @EnableFeignClients @SpringBootApplication public class OrderApplication {...3、創(chuàng)建 Feign 接口類
@FeignClient("service-product") public interface ProductService {@GetMapping("/product/{pid}")public Product findByPid(@PathVariable("pid") Integer pid); }4、將調(diào)用方式從 restTemplate 改為 Feign:
然后啟動訂單和商品微服務(wù),請求http://localhost:8091/order/prod/{pid} 接口發(fā)送下單請求:
可以看到商品信息無誤,說明訂單微服務(wù)已經(jīng)成功獲取到商品信息。
說明,以上案例的代碼做了大量的省略,主要是去掉了一些數(shù)據(jù)庫操作和配置等不必要的編碼展示,具體操作都已經(jīng)寫在《Spring Cloud Alibaba——Nacos實現(xiàn)服務(wù)治理》中。
?
總結(jié)
以上是生活随笔為你收集整理的Spring Cloud —— Feign 实现服务调用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 哈希表的大小为何最好是素数
- 下一篇: 扫地机器人划伤地板_扫地机器人哪个牌子好