欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java?Ribbon與openfeign區(qū)別和用法講解

 更新時(shí)間:2022年08月01日 08:43:31   作者:kaico2018  
Ribbon是基于Netflix?Ribbon實(shí)現(xiàn)的一套客戶端負(fù)載均衡的工具,主要功能是提供客戶端的軟件負(fù)載均衡算法和服務(wù)調(diào)用。openfeign對(duì)Feign進(jìn)行了增強(qiáng),使其支持Spring MVC注解,另外還整合了Ribbon和Nacos,從而使得Feign的使用更加方便

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引用類型interface的用法總結(jié)

    Java引用類型interface的用法總結(jié)

    這篇文章主要為大家詳細(xì)介紹了Java中引用類型interface的用法的相關(guān)資料,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Java有一定幫助,感興趣的可以了解一下
    2022-10-10
  • java實(shí)現(xiàn)微信支付功能

    java實(shí)現(xiàn)微信支付功能

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)微信支付功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • JDK更換IDEA如何修改圖文詳解

    JDK更換IDEA如何修改圖文詳解

    這篇文章主要給大家介紹了關(guān)于JDK更換IDEA如何修改的相關(guān)資料,Java的不同版本的JDK之間存在細(xì)微的差別,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • 在Java Spring框架中使用的設(shè)計(jì)模式有哪些

    在Java Spring框架中使用的設(shè)計(jì)模式有哪些

    面試中常會(huì)被問道Spring框架使用了哪些設(shè)計(jì)模式?關(guān)于這個(gè)問題本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • Java設(shè)計(jì)模式之備忘錄模式詳解

    Java設(shè)計(jì)模式之備忘錄模式詳解

    這篇文章主要介紹了Java設(shè)計(jì)模式之備忘錄模式詳解,備忘錄模式在不破壞封裝性的前提下,捕獲一個(gè)對(duì)象的內(nèi)部狀態(tài)并在該對(duì)象之外保存這個(gè)狀態(tài),這樣以后就可以將該對(duì)象恢復(fù)到原先保存的狀態(tài),需要的朋友可以參考下
    2023-12-12
  • 簡(jiǎn)單了解Spring中常用工具類

    簡(jiǎn)單了解Spring中常用工具類

    這篇文章主要介紹了簡(jiǎn)單了解Spring中常用工具類,非常全面,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-10-10
  • Spring Boot實(shí)現(xiàn)圖片上傳/加水印一把梭操作實(shí)例代碼

    Spring 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-11
  • Java中IO流 RandomAccessFile類實(shí)例詳解

    Java中IO流 RandomAccessFile類實(shí)例詳解

    這篇文章主要介紹了Java中IO流 RandomAccessFile類實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • SpringBoot使用JPA實(shí)現(xiàn)查詢部分字段

    SpringBoot使用JPA實(shí)現(xiàn)查詢部分字段

    這篇文章主要介紹了SpringBoot使用JPA實(shí)現(xiàn)查詢部分字段方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • webuploader在springMVC+jquery+Java開發(fā)環(huán)境下的大文件分片上傳的實(shí)例代碼

    webuploader在springMVC+jquery+Java開發(fā)環(huán)境下的大文件分片上傳的實(shí)例代碼

    這篇文章主要介紹了webuploader在springMVC+jquery+Java開發(fā)環(huán)境下的大文件分片上傳的實(shí)例代碼,需要的朋友可以參考下
    2017-04-04

最新評(píng)論