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