摘要:公眾號(hào)樂園的中提供了兩個(gè)組件實(shí)現(xiàn)軟負(fù)載均衡調(diào)用,分別是和。是基于和的客戶端負(fù)載工具,它是基于實(shí)現(xiàn)的,它可以在客戶端配置服務(wù)端列表,然后輪詢請(qǐng)求以實(shí)現(xiàn)均衡負(fù)載。
公眾號(hào):java樂園
spring cloud的Netflix中提供了兩個(gè)組件實(shí)現(xiàn)軟負(fù)載均衡調(diào)用,分別是Ribbon和Feign。上一篇和大家一起學(xué)習(xí)了Ribbon。
Ribbon :Spring Cloud Ribbon是基于HTTP和TCP的客戶端負(fù)載工具,它是基于Netflix Ribbon實(shí)現(xiàn)的,它可以在客戶端配置 ribbonServerList(服務(wù)端列表),然后輪詢請(qǐng)求以實(shí)現(xiàn)均衡負(fù)載。
Feign :spring cloud feign 是一個(gè)使用起來更加方便的 HTTP 客戶端。 在使用ribbon時(shí),通常會(huì)使用RestTemplate實(shí)現(xiàn)對(duì)http請(qǐng)求的封裝,形成了模板化的調(diào)用方法。spring cloud feign在此基礎(chǔ)上做了進(jìn)一步的封裝,F(xiàn)eign是一種聲明式、模板化的HTTP客戶端。在Spring Cloud中使用Feign, 可以做到使用HTTP請(qǐng)求遠(yuǎn)程服務(wù)時(shí)能與調(diào)用本地方法一樣的編碼體驗(yàn),完全感知不到這是遠(yuǎn)程方法,更感知不到這是個(gè)HTTP請(qǐng)求。
1、 新建項(xiàng)目sc-eureka-client-consumer-feign,對(duì)應(yīng)的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已經(jīng)被標(biāo)識(shí)為過期,推薦使用spring-cloud-starter-openfeign
2、 新建spring boot啟動(dòng)類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、 創(chuàng)建配置文件bootstrap.yml和application.yml,對(duì)應(yīng)的內(nèi)容如下
bootstrap.yml
server: port: 5800
application.yml
spring: application: name: sc-eureka-client-consumer-feign eureka: client: registerWithEureka: true #是否將自己注冊(cè)到Eureka服務(wù)中,默認(rèn)為true fetchRegistry: true #是否從Eureka中獲取注冊(cè)信息,默認(rèn)為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}") MapgetUser(@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、 分別啟動(dòng)注冊(cè)中心項(xiàng)目sc-eureka-server和服務(wù)提供者sc-eureka-client-provider
6、 啟動(dòng)項(xiàng)目sc-eureka-client-consumer-feign,并驗(yàn)證是否啟動(dòng)成功
方法一
方法二
7、 使用postman驗(yàn)證
查詢:
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項(xiàng)目的UserController.java 需要修正
源碼
https://gitee.com/hjj520/spring-cloud-2.x/tree/master/sc-eureka-client-consumer-feign
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/75090.html
摘要:一簡(jiǎn)介是一個(gè)聲明式的服務(wù)客戶端,它使得寫服務(wù)變得更簡(jiǎn)單。同時(shí)支持可插拔的編碼器和解碼器。對(duì)添加了支持,同時(shí)在中次用相同的。 轉(zhuǎn)載請(qǐng)標(biāo)明出處: http://blog.csdn.net/forezp/a...本文出自方志朋的博客 上一篇文章,講述了通過restTemplate+ribbon去消費(fèi)服務(wù),這篇文章主要講述通過feign去消費(fèi)服務(wù)。 一、Feign簡(jiǎn)介 Feign是一個(gè)聲明式的...
摘要:多層服務(wù)調(diào)用常見于微服務(wù)架構(gòu)中較底層的服務(wù)如果出現(xiàn)故障,會(huì)導(dǎo)致連鎖故障。 Spring Cloud 體驗(yàn) 簡(jiǎn)介 Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)的一些工具,包括配置管理、服務(wù)發(fā)現(xiàn)、斷路器、路由、微代理、 事件總線、全局鎖、決策競(jìng)選、分布式會(huì)話等等 基于Spring Boot,Spring Cloud將各公司成熟服務(wù)框架組合起來,通過Spring Boo...
摘要:那么為什么可以帶給我們這樣的完美編碼體驗(yàn)?zāi)貙?shí)際上,這完全歸功于的封裝,由于在服務(wù)注冊(cè)與發(fā)現(xiàn)客戶端負(fù)載均衡等方面都做了很好的抽象,而上層應(yīng)用方面依賴的都是這些抽象接口,而非針對(duì)某個(gè)具體中間件的實(shí)現(xiàn)。 通過《Spring Cloud Alibaba基礎(chǔ)教程:使用Nacos實(shí)現(xiàn)服務(wù)注冊(cè)與發(fā)現(xiàn)》一文的學(xué)習(xí),我們已經(jīng)學(xué)會(huì)如何使用Nacos來實(shí)現(xiàn)服務(wù)的注冊(cè)與發(fā)現(xiàn),同時(shí)也介紹如何通過LoadBala...
摘要:服務(wù)消費(fèi)者可以使用多種模型來發(fā)現(xiàn)服務(wù)。客戶端將定期與服務(wù)發(fā)現(xiàn)層進(jìn)行通信,并刷新服務(wù)實(shí)例的緩存。為了達(dá)成目的,我們將要學(xué)習(xí)使用個(gè)不同的客戶端庫,服務(wù)消費(fèi)者可以使用它們來和進(jìn)行交互。 本篇代碼存放于:github 一、服務(wù)發(fā)現(xiàn)架構(gòu) ??服務(wù)發(fā)現(xiàn)架構(gòu)通常具有下面 4 個(gè)概念: 服務(wù)注冊(cè):服務(wù)如何使用服務(wù)發(fā)現(xiàn)代理進(jìn)行注冊(cè)? 服務(wù)地址的客戶端查找:服務(wù)客戶端查找服務(wù)信息的方法是什么? 信息共享...
摘要:三實(shí)踐案例案例簡(jiǎn)介分布式系統(tǒng)中,微服務(wù)基礎(chǔ)組件等,系統(tǒng)中間件,等,對(duì)常用功能配置等,進(jìn)行二次淺封裝并統(tǒng)一集成管理,以滿足日常開發(fā)中基礎(chǔ)環(huán)境搭建與臨時(shí)工具的快速實(shí)現(xiàn)。 一、背景簡(jiǎn)介 分布式系統(tǒng)中存在很多拆分的服務(wù),在不斷迭代升級(jí)的過程中,會(huì)出現(xiàn)如下常見的棘手情況: 某個(gè)技術(shù)組件版本升級(jí),依賴包升級(jí)導(dǎo)致部分語法或者API過期,或者組件修復(fù)緊急的問題,從而會(huì)導(dǎo)致分布式系統(tǒng)下各個(gè)服...
閱讀 2847·2021-09-28 09:36
閱讀 3937·2021-09-22 15:52
閱讀 3630·2021-09-06 15:00
閱讀 1947·2021-09-02 15:40
閱讀 2798·2021-09-02 15:15
閱讀 3454·2021-08-17 10:15
閱讀 2781·2019-08-30 15:53
閱讀 2073·2019-08-29 18:39