国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

8、服務發現&服務消費者Feign

lpjustdoit / 3521人閱讀

摘要:公眾號樂園的中提供了兩個組件實現軟負載均衡調用,分別是和。是基于和的客戶端負載工具,它是基于實現的,它可以在客戶端配置服務端列表,然后輪詢請求以實現均衡負載。

公眾號:java樂園

spring cloud的Netflix中提供了兩個組件實現軟負載均衡調用,分別是Ribbon和Feign。上一篇和大家一起學習了Ribbon。
Ribbon :Spring Cloud Ribbon是基于HTTP和TCP的客戶端負載工具,它是基于Netflix Ribbon實現的,它可以在客戶端配置 ribbonServerList(服務端列表),然后輪詢請求以實現均衡負載。
Feign :spring cloud feign 是一個使用起來更加方便的 HTTP 客戶端。 在使用ribbon時,通常會使用RestTemplate實現對http請求的封裝,形成了模板化的調用方法。spring cloud feign在此基礎上做了進一步的封裝,Feign是一種聲明式、模板化的HTTP客戶端。在Spring Cloud中使用Feign, 可以做到使用HTTP請求遠程服務時能與調用本地方法一樣的編碼體驗,完全感知不到這是遠程方法,更感知不到這是個HTTP請求。

1、 新建項目sc-eureka-client-consumer-feign,對應的pom.xml文件如下


    4.0.0

    spring-cloud
    sc-eureka-client-consumer-feign
    0.0.1-SNAPSHOT
    jar

    sc-eureka-client-consumer-feign
    http://maven.apache.org

    
        org.springframework.boot
        spring-boot-starter-parent
        2.0.4.RELEASE
    

    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                Finchley.RELEASE
                pom
                import
            

        
    

    
        UTF-8
        1.8
        1.8
    

    
    
        
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        

        
            org.springframework.boot
            spring-boot-starter-web
        
        
        

        
            org.springframework.cloud
            spring-cloud-starter-openfeign
        
        
    


備注:spring cloud 2.x后spring-cloud-starter-feign已經被標識為過期,推薦使用spring-cloud-starter-openfeign

2、 新建spring boot啟動類ConsumerFeignApplication.java

package sc.consumer;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class ConsumerFeignApplication {
    
    public static void main(String[] args) {
        SpringApplication.run(ConsumerFeignApplication.class, args);
    }

}

3、 創建配置文件bootstrap.yml和application.yml,對應的內容如下

bootstrap.yml

server:
  port: 5800

application.yml

spring:
  application:
    name: sc-eureka-client-consumer-feign

eureka:
  client:
    registerWithEureka: true #是否將自己注冊到Eureka服務中,默認為true
    fetchRegistry: true #是否從Eureka中獲取注冊信息,默認為true
    serviceUrl:
      defaultZone: http://localhost:5001/eureka/

4、 編寫feign客戶端

package sc.consumer.service;

import java.util.Map;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;

import sc.consumer.model.User;

@FeignClient(value="sc-eureka-client-provider")
public interface UserService {

    @GetMapping("/user/getUser/{id}")
    Map getUser(@PathVariable(value ="id") Long id);

    @RequestMapping("/user/listUser")
    Map listUser();

    @PostMapping("/user/addUser")
    Map addUser(@RequestBody User user);

    @PutMapping("/user/updateUser")
    Map updateUser(@RequestBody User user);

    @DeleteMapping("/user/deleteUser/{id}")
    Map deleteUser(@PathVariable(value ="id") Long id);

}

5、 分別啟動注冊中心項目sc-eureka-server和服務提供者sc-eureka-client-provider

6、 啟動項目sc-eureka-client-consumer-feign,并驗證是否啟動成功
方法一

方法二

7、 使用postman驗證
查詢:
http://127.0.0.1:5800/feign/user/getUser/4

列表:
http://127.0.0.1:5800/feign/user/listUser

添加:
http://127.0.0.1:5800/feign/user/addUser

更新:
http://127.0.0.1:5800/feign/user/updateUser

刪除:
http://127.0.0.1:5800/feign/user/deleteUser/6

備注:
sc-eureka-client-provider項目的UserController.java 需要修正

源碼

https://gitee.com/hjj520/spring-cloud-2.x/tree/master/sc-eureka-client-consumer-feign

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/75090.html

相關文章

  • 史上最簡單的SpringCloud教程 | 第三篇: 服務費者Feign

    摘要:一簡介是一個聲明式的服務客戶端,它使得寫服務變得更簡單。同時支持可插拔的編碼器和解碼器。對添加了支持,同時在中次用相同的。 轉載請標明出處: http://blog.csdn.net/forezp/a...本文出自方志朋的博客 上一篇文章,講述了通過restTemplate+ribbon去消費服務,這篇文章主要講述通過feign去消費服務。 一、Feign簡介 Feign是一個聲明式的...

    0x584a 評論0 收藏0
  • Spring Cloud 體驗

    摘要:多層服務調用常見于微服務架構中較底層的服務如果出現故障,會導致連鎖故障。 Spring Cloud 體驗 簡介 Spring Cloud為開發人員提供了快速構建分布式系統的一些工具,包括配置管理、服務發現、斷路器、路由、微代理、 事件總線、全局鎖、決策競選、分布式會話等等 基于Spring Boot,Spring Cloud將各公司成熟服務框架組合起來,通過Spring Boo...

    NotFound 評論0 收藏0
  • Spring Cloud Alibaba基礎教程:支持的幾種服務消費方式

    摘要:那么為什么可以帶給我們這樣的完美編碼體驗呢實際上,這完全歸功于的封裝,由于在服務注冊與發現客戶端負載均衡等方面都做了很好的抽象,而上層應用方面依賴的都是這些抽象接口,而非針對某個具體中間件的實現。 通過《Spring Cloud Alibaba基礎教程:使用Nacos實現服務注冊與發現》一文的學習,我們已經學會如何使用Nacos來實現服務的注冊與發現,同時也介紹如何通過LoadBala...

    curlyCheng 評論0 收藏0
  • springCloud學習2(服務發現)

    摘要:服務消費者可以使用多種模型來發現服務。客戶端將定期與服務發現層進行通信,并刷新服務實例的緩存。為了達成目的,我們將要學習使用個不同的客戶端庫,服務消費者可以使用它們來和進行交互。 本篇代碼存放于:github 一、服務發現架構 ??服務發現架構通常具有下面 4 個概念: 服務注冊:服務如何使用服務發現代理進行注冊? 服務地址的客戶端查找:服務客戶端查找服務信息的方法是什么? 信息共享...

    史占廣 評論0 收藏0
  • 服務架構中,二次淺封裝實踐

    摘要:三實踐案例案例簡介分布式系統中,微服務基礎組件等,系統中間件,等,對常用功能配置等,進行二次淺封裝并統一集成管理,以滿足日常開發中基礎環境搭建與臨時工具的快速實現。 一、背景簡介 分布式系統中存在很多拆分的服務,在不斷迭代升級的過程中,會出現如下常見的棘手情況: 某個技術組件版本升級,依賴包升級導致部分語法或者API過期,或者組件修復緊急的問題,從而會導致分布式系統下各個服...

    Hujiawei 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<