什麼是Feign
Feign是spring cloud提供的一個聲明式的僞http用戶端,它使得調用遠端服務就像調用本地服務一樣簡單,隻需要建立一個接口并添加一個注解即可。
Nacos很好的相容了Feign,Feign預設預設繼承了Ribbon,是以在nacos下使用Feign預設就實作了負載均衡的效果。
Ribbon支援的負載均衡政策
負載均衡就是将請求分攤給多個執行個體進行進行處理。
根據負載均衡發生位置的不同,一般分為服務端負載均衡和用戶端負載均衡。
服務端負載均衡指的是發生在服務提供者一方,比如常見的nginx負載均衡。
用戶端負載均衡指的是發生在服務請求的一方,也就是在服務請求之前已經選好了由哪個執行個體進行處理。
我們在微服務中一般會選擇用戶端負載均衡,Ribbon就是在用戶端進行了負載。
Ribbon内置了多種負載均衡政策,内部負載均衡的頂級接口為:com.netflix.loadbalancer.IRule,具體的負載政策如下圖所示:
政策類 | 命名 | 描述 |
---|---|---|
RandomRule | 随機政策 | 随機選擇server |
RoundRobinRule | 輪詢政策 | 按照順序選擇server(ribbon預設政策) |
RetryRule | 重試政策 | 在一個配置時間段内,當選擇server不成功,則一直嘗試選擇一個可用的server |
BestAvailableRule | 最低并發政策 | 逐個考察server,如果server斷路器打開,則忽略,再選擇其中并發連結最低的server |
AvailabilityFilteringRule | 可用過濾政策 | 過濾掉一直失敗并被标記為circuit tripped的server,過濾掉那些高并發連結的server(active connections超過配置的門檻值) |
ResponseTimeWeightedRule | 響應時間權重重政策 | 根據server的響應時間配置設定權重,響應時間越長,權重越低,被選擇到的機率也就越低。響應時間越短,權重越高,被選中的機率越高,這個政策很貼切,綜合了各種因素,比如:網絡,磁盤,io等,都直接影響響應時間 |
ZoneAvoidanceRule | 區域權重政策 | 綜合判斷server所在區域的性能,和server的可用性,輪詢選擇server并且判斷一個AWS Zone的運作性能是否可用,剔除不可用的Zone中的所有server |
如何使用Feign
我們使用第一章中的nacos-discovery-server作為服務提供者,提供了一個“/hello”的接口。建立一個alibaba-client-feign的服務作為消費者。
- pom檔案中假如openfeign的依賴
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
- 在啟動類上加上支援feign的注解
@EnableFeignClients // 開啟feign
- 建立一個feign用戶端并使用feign調用微服務
@RestController
class TestController{
@Autowired
Client client;
@GetMapping("/test")
String test(){
return client.hello("hahaha");
}
}
@FeignClient(name="nacos-discovery-server")
interface Client{
@GetMapping("/hello")
String hello(@RequestParam String name);
}
注意:在實際開發中,feign用戶端都是寫在公共子產品當中,哪個服務需要調用引入公共子產品即可。
Feign的兩種實作方式
- 第一種就是本文中介紹的,Feign和生産者的RequestMapping保持一緻。
- 第二種是在feignClient中提供所有請求的接口,然後controller實作這個feignClient,這樣就不必要寫重複代碼了。
注意點
- 請求參數為對象是,使用@requestbody
- 請求參數用@requestParam接收時,必須加上value屬性,如@requestParam("name")
- 請求參數用@pathVariable接收時,必須加上value屬性,如@pathVariable("name")