Java?Ribbon與openfeign區(qū)別和用法講解
Ribbon 本地負載均衡器
在SpringCloud第一代中使用Ribbon、SpringCloud第二代中直接采用自研發(fā) loadbalancer 即可,默認使用的Ribbon。
本地負載均衡與Nginx 的區(qū)別
本地負載均衡器基本的概念:我們的消費者服務從我們的注冊中心獲取到集群地址列表,緩存到本地,讓后本地采用負載均衡策略(輪訓、隨機、權(quán)重、hash一致性等),獲取接口列表地址,采用算法獲取選擇一個接口地址實現(xiàn)本地的rpc遠程的。本地負載均衡器是從注冊中心獲取到集群地址列表,本地實現(xiàn)負載均衡算法,既本地負載均衡器。
Nginx是客戶端所有的請求統(tǒng)一都交給我們的Nginx處理,讓后在由Nginx實現(xiàn)負載均衡轉(zhuǎn)發(fā),屬于服務器端負載均衡器。
應用場景:
Nginx屬于服務器負載均衡,應用于Tomcat/Jetty服務器等,而我們的本地負載均衡器,屬于客戶端負載均衡,應用于在微服務架構(gòu)中rpc框架中,rest、openfeign、dubbo。
基本使用
注入 restTemplate,加上 @LoadBalanced 注解。
@Bean("restTemplate") @LoadBalanced // 實現(xiàn)本地的負載均衡 public RestTemplate restTemplate(){ return new RestTemplate(); }
請求路徑上可以換成服務的名稱
@RequestMapping("/orderToMember") public String orderToMember() { // 使用本地rest形式實現(xiàn)rpc調(diào)用 String result = restTemplate.getForObject("http://kaico-member/getUser", String.class); return "訂單調(diào)用會員獲取結(jié)果:" + result; }
使用 loadBalancerClient 實現(xiàn)負載均衡
@RequestMapping("/orderToMember") public String orderToMember() { // 使用本地rest形式實現(xiàn)rpc調(diào)用 ServiceInstance choose = loadBalancerClient.choose("kaico-member"); return "獲取結(jié)果:" + choose; }
原理分析
ServiceInstance choose = loadBalancerClient.choose(“kaico-member”); 從這行代碼分析,
客戶端負載均衡器源碼:
根據(jù)serviceId獲取服務
可以支持的算法:默認是輪訓
openfeign
openFeign是一個Web聲明式的Http客戶端調(diào)用工具,提供接口和注解形式調(diào)用。
openfeign客戶端作用:是一個Web聲明式的Http客戶端遠程遠程調(diào)用工具,底層是封裝 HttpClient 技術(shù)。
openfeign屬于 SpringCloud 自己研發(fā),而 feign 是 netflix 研發(fā)的。
基本使用
提供服務方
接口
public interface MenberService { /** * 提供會員接口 * * @param userId * @return */ @GetMapping("/getUser") String getUser(@RequestParam("userId") Long userId); }
接口的實現(xiàn)類
@RestController public class MenberServiceImpl implements MenberService { @Value("${server.port}") private String serverPort; @Override public String getUser(Long userId) { return "我是會員服務端口號為:" + serverPort; } }
此時,服務方提供的接口已經(jīng)準備好了
接下來編寫接口調(diào)用方的代碼:
1、引入maven 依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>2.0.0.RELEASE</version> </dependency>
2、啟動類上開啟openfeign 注解:@EnableFeignClients
3、編寫 feignClient 接口
@FeignClient(name = "kaico-member") public interface MenberServiceFeign{ /** * 提供會員接口 * * @param userId * @return */ @GetMapping("/getUser") String getUser(@RequestParam("userId") Long userId); }
4、直接調(diào)用 MenberServiceFeign 接口的方法
@Autowired private MenberServiceFeign menberServiceFeign; @RequestMapping("/orderToMember") public String orderToMember() { //測試openfeign 調(diào)用接口 String user = menberServiceFeign.getUser(1L); return "獲取結(jié)果:" + user; }
總結(jié):調(diào)用方在編寫feignClient 接口代碼時,只要方法代碼和注解和提供方法接口代碼一致即可,不要求類的全路徑名稱一致。然后在接口類上加上注解@FeignClient(name = “kaico-member”)并指定服務名稱。openfeign默認是支持負載均衡:輪訓算法(ribbon)
微服務的服務名稱不能有下劃線。
到此這篇關(guān)于Java Ribbon與openfeign區(qū)別和用法講解的文章就介紹到這了,更多相關(guān)Java Ribbon與openfeign內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在Java Spring框架中使用的設(shè)計模式有哪些
面試中常會被問道Spring框架使用了哪些設(shè)計模式?關(guān)于這個問題本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09Spring Boot實現(xiàn)圖片上傳/加水印一把梭操作實例代碼
這篇文章主要給大家介紹了關(guān)于Spring Boot實現(xiàn)圖片上傳/加水印一把梭操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-11-11Java中IO流 RandomAccessFile類實例詳解
這篇文章主要介紹了Java中IO流 RandomAccessFile類實例詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05webuploader在springMVC+jquery+Java開發(fā)環(huán)境下的大文件分片上傳的實例代碼
這篇文章主要介紹了webuploader在springMVC+jquery+Java開發(fā)環(huán)境下的大文件分片上傳的實例代碼,需要的朋友可以參考下2017-04-04