SpringCloud中Ribbon和Feign組件如何使用,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)建站是一家專業(yè)提供古浪企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站制作、成都做網(wǎng)站、H5響應(yīng)式網(wǎng)站、小程序制作等業(yè)務(wù)。10年已為古浪眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。Ribbon是一個(gè)客戶端的負(fù)載均衡(Load Balancer,簡(jiǎn)稱LB)器,它提供對(duì)大量的HTTP和TCP客戶端的訪問控制。
目前主流的負(fù)載均衡方案可分成兩類:
1)集中式
即在服務(wù)的消費(fèi)方和提供方之間使用獨(dú)立的LB設(shè)施,可以是硬件,如F5,也可以是軟件,如nginx,由該設(shè)施負(fù)責(zé)把訪問請(qǐng)求通過某種策略轉(zhuǎn)發(fā)至服務(wù)的提供方;
2)進(jìn)程內(nèi)
將LB邏輯集成到消費(fèi)方,消費(fèi)方從服務(wù)注冊(cè)中心獲取可用服務(wù)列表,然后根據(jù)指定負(fù)載均衡策略選擇合適的服務(wù)器。Ribbon就屬于該方式。
1) RoundRobinRule 輪詢 輪詢服務(wù)列表List<Server>的index,選擇index對(duì)應(yīng)位置的服務(wù)。 2) RandomRule 隨機(jī) 隨機(jī)服務(wù)列表List<Server>的index,選擇index對(duì)應(yīng)位置的服務(wù)。 3) RetryRule 重試 指定時(shí)間內(nèi),重試(請(qǐng)求)某個(gè)服務(wù)不成功達(dá)到指定次數(shù),則不再請(qǐng)求該服務(wù)。
1、基本概念
Feign 是一個(gè)聲明式的 Web Service 客戶端。它的出現(xiàn)使開發(fā) Web Service 客戶端變得很簡(jiǎn)單。使用 Feign 只需要?jiǎng)?chuàng)建一個(gè)接口加上對(duì)應(yīng)的注解,比如: @FeignClient 接口類注解。
2、執(zhí)行流程
1) 主程序入口添加 @EnableFeignClients 注解開啟對(duì) FeignClient 接口掃描加載。接口使用 @FeignClient注解。
2) 調(diào)用Feign 接口中的方法被時(shí),通過JDK的代理的方式,生成具體的 RequestTemplate。
3) RequestTemplate 生成 Request請(qǐng)求,結(jié)合Ribbon實(shí)現(xiàn)服務(wù)調(diào)用負(fù)載均衡策略。
1)、模塊描述
Eureka注冊(cè)中心 node02-eureka-7001 兩個(gè)服務(wù)提供方 node02-provider-6001 node02-provider-6002 Ribbon服務(wù)調(diào)用 node02-consume-8001 Feign服務(wù)調(diào)用 node02-consume-8002
2)、依賴Eureka知識(shí)
上篇文章Eureka使用:
代碼所屬模塊:node02-consume-8001
1)、核心依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-ribbon</artifactId> </dependency>
2)、配置文件
@Configuration public class LoadConfig { @Bean @LoadBalanced public RestTemplate getRestTemplate (){ return new RestTemplate() ; } @Bean public IRule getIRule (){ // 默認(rèn)輪詢算法 // return new RoundRobinRule() ; // 重試算法:默認(rèn)情況,訪問某個(gè)服務(wù)連續(xù)三次失敗,就不會(huì)再訪問 // return new RetryRule() ; // 隨機(jī)算法 return new RandomRule() ; } }
3)、調(diào)用方式
@RestController public class ConsumeController { @Autowired private RestTemplate restTemplate ; String server_name = "http://NODE02-PROVIDER" ; // http://localhost:8001/showInfo @RequestMapping("/showInfo") public String showInfo (){ return restTemplate.getForObject(server_name+"/getInfo",String.class) ; } }
這里的NODE02-PROVIDER就是服務(wù)提供方的配置文件。兩個(gè)服務(wù)提供方的這塊配置相同,Ribbon正基于此,實(shí)現(xiàn)多個(gè)服務(wù)調(diào)用的負(fù)載均衡。
spring: application: name: node02-provider
4)、提供方接口
@RequestMapping("/getInfo") public String getInfo (){ LOG.info("provider-6002"); return "success" ; }
代碼所屬模塊:node02-consume-8002
1)、核心依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-feign</artifactId> </dependency>
2)、配置文件
@FeignClient(value = "NODE02-PROVIDER") public interface GetAuthorService { @RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET) String getAuthorInfo (@PathVariable("authorId") String authorId) ; }
3)、調(diào)用方式
@RestController public class ConsumeController { @Resource private GetAuthorService getAuthorService ; @RequestMapping(value = "/getAuthorInfo") public String getAuthorInfo () { return getAuthorService.getAuthorInfo("1") ; } }
4)、啟動(dòng)類注解
// 因?yàn)榘窂讲煌?,需要加basePackages屬性 @EnableFeignClients(basePackages={"cloud.block.code.service"})
5)、提供方接口
@RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET) public String getAuthorInfo (@PathVariable("authorId") String authorId) { LOG.info("provider-6002"); return "知了一笑"+authorId ; }
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。
文章題目:SpringCloud中Ribbon和Feign組件如何使用-創(chuàng)新互聯(lián)
網(wǎng)站網(wǎng)址:http://www.rwnh.cn/article18/cceidp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、企業(yè)建站、網(wǎng)站改版、ChatGPT、響應(yīng)式網(wǎng)站、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容