SpringCloud筆記(Hoxton)Netflix之Ribbon負(fù)載均衡示例代碼
Ribbon使用
- Ribbon是管理HTTP和TCP服務(wù)客戶端的負(fù)載均衡器,Ribbon具有一系列帶有名稱的客戶端(Named Client),也就是帶有名稱的Ribbon客戶端(Ribbon Client)。
- 每個(gè)客戶端由可配置的組件構(gòu)成,負(fù)責(zé)一類服務(wù)的調(diào)用請(qǐng)求。SpringCloud通RibbonClientConfiguration 為每個(gè)Ribbon客戶端創(chuàng)建ApplicationContext上下文來(lái)進(jìn)行組件裝配。Ribbon作為SpringCloud的負(fù)載均衡機(jī)制的實(shí)現(xiàn),可以與OpenFeign和RestTemplate進(jìn)行無(wú)縫對(duì)接,讓二者具有負(fù)載均衡的能力。
負(fù)載均衡
- 當(dāng)系統(tǒng)面臨大量的用戶訪問(wèn),負(fù)載過(guò)高的時(shí)候,通常會(huì)增加服務(wù)器數(shù)量來(lái)進(jìn)行橫向擴(kuò)展,多個(gè)服務(wù)器的負(fù)載需要均衡,以免出現(xiàn)服務(wù)器負(fù)載不均衡,部分服務(wù)器負(fù)載較大,部分服務(wù)器負(fù)載較小的情況 通過(guò)負(fù)載均衡,使得集群中服務(wù)器的負(fù)載保持在穩(wěn)定高效的狀態(tài),從而提高整個(gè)系統(tǒng)的處理能力。
- 系統(tǒng)的負(fù)載均衡分為軟件負(fù)載均衡和硬件負(fù)載均衡,軟件負(fù)載均衡使用獨(dú)立的負(fù)載均衡程序或系統(tǒng)自帶的負(fù)載均衡模塊完成對(duì)請(qǐng)求的分配派發(fā),硬件負(fù)載均衡通過(guò)特殊的硬件設(shè)備進(jìn)行負(fù)載均衡的調(diào)配。
- 軟負(fù)載均衡一般分為兩種類型,基于DNS負(fù)載均衡和基于IP的負(fù)載均衡。利用DNS 實(shí)現(xiàn)負(fù)載均衡,就是在DNS服務(wù)器配置多個(gè)A記錄,不同的 DNS請(qǐng)求解析到不同IP地址?;贗P的負(fù)載均衡根據(jù)請(qǐng)求的IP 行負(fù)載均衡,LVS就是具有代表性的基于IP負(fù)載均衡實(shí)現(xiàn)。
- Ribbon使用的是客戶端負(fù)載均衡,客戶端負(fù)載均衡和服務(wù)端負(fù)載均衡最大的區(qū)別在于服務(wù)端地址列表的存儲(chǔ)位置,在客戶端負(fù)載均衡中,所有的客戶端節(jié)點(diǎn)都有一份自己要訪問(wèn)的服務(wù)端地址列表,這些列表統(tǒng)統(tǒng)都是從服務(wù)注冊(cè)中心獲取的;而在服務(wù)端負(fù)載均衡中,客戶端節(jié)點(diǎn)只知道單一服務(wù)代理的地址,服務(wù)代理則知道所有服務(wù)端的地址。在SpringCloud中我們?nèi)绻胍褂每蛻舳素?fù)載均衡,可以使用@LoadBalanced注解,這樣客戶端在發(fā)起請(qǐng)求的時(shí)候會(huì)根據(jù)負(fù)載均衡策略從服務(wù)端列表中選擇一個(gè)服務(wù)端,向該服務(wù)端發(fā)起網(wǎng)絡(luò)請(qǐng)求,從而實(shí)現(xiàn)負(fù)載均衡。
代碼示例
注冊(cè)中心
這里是Eureka作為服務(wù)注冊(cè)中心,為OpenFeign提供服務(wù)端信息的獲取,比如說(shuō)服務(wù)的IP地址和端口,使用前面搭建好的項(xiàng)目(eureka-server)。
Provider
在idea中新建兩個(gè)項(xiàng)目運(yùn)行主類,選擇前面創(chuàng)建好的項(xiàng)目(eureka-provider)。
設(shè)置不同運(yùn)行主類,使用不同端口號(hào),然后啟動(dòng)三個(gè)不同端口號(hào)的provider。
接口實(shí)現(xiàn)
調(diào)用不同的服務(wù)端,會(huì)返回對(duì)應(yīng)服務(wù)端的接口。
@RestController @RequestMapping("/api") public class PoroviderController { @Value("${server.port}") private String serverPort; @PostMapping("/sayHello") public String sayHello(String name) { return "我是服務(wù)端" + serverPort + ",你好" + name; } }
Consumer
新建一個(gè)spring-boot工程,取名為consumer-ribbon,在pom文件引入ribbon需要的依賴。
添加依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-ribbon</artifactId> </dependency>
配置端口、注冊(cè)中心等
server: port: 8091 servlet: context-path: /ribbon eureka: client: service-url: defaultZone: http://localhost:8761/eureka/ instance: status-page-url-path: ${server.servlet.context-path}/info health-check-url-path: ${server.servlet.context-path}/health spring: application: name: consumer-ribbon
- 負(fù)載均衡策略 SpringCloud為客戶端負(fù)載均衡創(chuàng)建了特定的注解@LoadBalanced,我們只需要使用該注解修飾創(chuàng)建RestTemplate實(shí)例的@Bean函數(shù),SpringCloud就會(huì)讓RestTemplate使用相關(guān)的負(fù)載均衡策略,默認(rèn)情況下使用Ribbon。
- 除了@LoadBalanced之外,Ribbon還提供@RibbonClient注解。該注解可以為Ribbon客戶端聲明名稱和自定義配置。 name屬性可以設(shè)置客戶端的名稱, configuration屬性則會(huì)設(shè)置Ribbon相關(guān)的自定義配 類。
@Configuration public class RestTemplateConfig { /** * @return org.springframework.web.client.RestTemplate * @description 注入一個(gè)可以進(jìn)行負(fù)載均衡的RestTemple用于服務(wù)問(wèn)調(diào)用 * @author fengfan * @date 2022/5/18 14:43 */ @Bean @LoadBalanced public RestTemplate restTemplate(){ return new RestTemplate(); } }
yml配置負(fù)載均衡策略
# 配置的方式設(shè)置Ribbon的負(fù)載均衡策略 EUREKA-PROVIDER: # 設(shè)置服務(wù)提供方的應(yīng)用名稱 ribbon: NFloadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 策略類(全路徑名)
代碼方式配置負(fù)載均衡策略
@Configuration public class RibbonConfig { /** * @return com.netflix.loadbalancer.IRule * @description 配置隨機(jī)負(fù)載策略 * @author fengfan * @date 2022/5/20 16:04 */ @Bean public IRule iRule(){ return new RandomRule(); } } @SpringBootApplication @EnableEurekaClient @RibbonClient(name = "consumer-ribbon", configuration = RibbonConfig.class) public class ConsumerRibbonApplication { public static void main(String[] args) { SpringApplication.run(ConsumerRibbonApplication.class, args); } }
客戶端調(diào)用實(shí)現(xiàn)
@RestController @RequestMapping("/api") public class ConsumerRibbonController { @Resource private RestTemplate restTemplate; @PostMapping("/getServerInfo") public String getServerInfo(){ MultiValueMap<String, String> body = new LinkedMultiValueMap<>(); body.add("name", "consumer8081"); ResponseEntity<String> responseEntity = restTemplate.postForEntity("http://EUREKA-PROVIDER/provider/api/sayHello", body, String.class); return responseEntity.getBody(); } }
測(cè)試
多次請(qǐng)求的服務(wù)端,端口隨機(jī)變化,證明配置成功。
到此這篇關(guān)于SpringCloud筆記(Hoxton)Netflix之Ribbon負(fù)載均衡示例代碼的文章就介紹到這了,更多相關(guān)SpringCloud Ribbon負(fù)載均衡內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解在Spring中如何使用AspectJ來(lái)實(shí)現(xiàn)AOP
這篇文章主要介紹了詳解在Spring中如何使用AspectJ來(lái)實(shí)現(xiàn)AOP,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06JAVA獲取rabbitmq消息總數(shù)過(guò)程詳解
這篇文章主要介紹了JAVA獲取rabbitmq消息總數(shù)過(guò)程詳解,公司使用的是rabbitMQ,需要做監(jiān)控預(yù)警的job去監(jiān)控rabbitMQ里面的堆積消息個(gè)數(shù),如何使用rabbitMQ獲取監(jiān)控的隊(duì)列里面的隊(duì)列消息個(gè)數(shù)呢,需要的朋友可以參考下2019-07-07基于Spring實(shí)現(xiàn)零重啟自由編排任務(wù)的定時(shí)管理器
我們發(fā)現(xiàn),我們使用Spring自帶的定時(shí)任務(wù)如果要有修改,那么就要修改代碼,然后重啟項(xiàng)目,所以本文就帶大家實(shí)現(xiàn)一個(gè)零重啟自由編排任務(wù)的定時(shí)管理器吧2023-07-07java 自己實(shí)現(xiàn)DataSource實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了java 自己實(shí)現(xiàn)DataSource實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05使用RestTemplate調(diào)用RESTful?API的代碼示例
在開(kāi)發(fā)?Web?應(yīng)用程序時(shí),調(diào)用?RESTful?API?是一個(gè)常見(jiàn)的任務(wù),本文將介紹如何使用?RestTemplate?調(diào)用?RESTful?API,并提供示例代碼,感興趣的同學(xué)可以跟著小編一起來(lái)看看2023-06-06工廠方法模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了工廠方法模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理的相關(guān)資料,需要的朋友可以參考下2017-08-08