SpringCloud筆記(Hoxton)Netflix之Ribbon負載均衡示例代碼
Ribbon使用
- Ribbon是管理HTTP和TCP服務客戶端的負載均衡器,Ribbon具有一系列帶有名稱的客戶端(Named Client),也就是帶有名稱的Ribbon客戶端(Ribbon Client)。
- 每個客戶端由可配置的組件構成,負責一類服務的調用請求。SpringCloud通RibbonClientConfiguration 為每個Ribbon客戶端創建ApplicationContext上下文來進行組件裝配。Ribbon作為SpringCloud的負載均衡機制的實現,可以與OpenFeign和RestTemplate進行無縫對接,讓二者具有負載均衡的能力。
負載均衡
- 當系統面臨大量的用戶訪問,負載過高的時候,通常會增加服務器數量來進行橫向擴展,多個服務器的負載需要均衡,以免出現服務器負載不均衡,部分服務器負載較大,部分服務器負載較小的情況 通過負載均衡,使得集群中服務器的負載保持在穩定高效的狀態,從而提高整個系統的處理能力。
- 系統的負載均衡分為軟件負載均衡和硬件負載均衡,軟件負載均衡使用獨立的負載均衡程序或系統自帶的負載均衡模塊完成對請求的分配派發,硬件負載均衡通過特殊的硬件設備進行負載均衡的調配。
- 軟負載均衡一般分為兩種類型,基於DNS負載均衡和基於IP的負載均衡。利用DNS 實現負載均衡,就是在DNS服務器配置多個A記錄,不同的 DNS請求解析到不同IP地址。基於IP的負載均衡根據請求的IP 行負載均衡,LVS就是具有代表性的基於IP負載均衡實現。
- Ribbon使用的是客戶端負載均衡,客戶端負載均衡和服務端負載均衡最大的區別在於服務端地址列表的存儲位置,在客戶端負載均衡中,所有的客戶端節點都有一份自己要訪問的服務端地址列表,這些列表統統都是從服務註冊中心獲取的;而在服務端負載均衡中,客戶端節點隻知道單一服務代理的地址,服務代理則知道所有服務端的地址。在SpringCloud中我們如果想要使用客戶端負載均衡,可以使用@LoadBalanced註解,這樣客戶端在發起請求的時候會根據負載均衡策略從服務端列表中選擇一個服務端,向該服務端發起網絡請求,從而實現負載均衡。
代碼示例
註冊中心
這裡是Eureka作為服務註冊中心,為OpenFeign提供服務端信息的獲取,比如說服務的IP地址和端口,使用前面搭建好的項目(eureka-server)。
Provider
在idea中新建兩個項目運行主類,選擇前面創建好的項目(eureka-provider)。
設置不同運行主類,使用不同端口號,然後啟動三個不同端口號的provider。
接口實現
調用不同的服務端,會返回對應服務端的接口。
@RestController @RequestMapping("/api") public class PoroviderController { @Value("${server.port}") private String serverPort; @PostMapping("/sayHello") public String sayHello(String name) { return "我是服務端" + serverPort + ",你好" + name; } }
Consumer
新建一個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>
配置端口、註冊中心等
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
- 負載均衡策略 SpringCloud為客戶端負載均衡創建瞭特定的註解@LoadBalanced,我們隻需要使用該註解修飾創建RestTemplate實例的@Bean函數,SpringCloud就會讓RestTemplate使用相關的負載均衡策略,默認情況下使用Ribbon。
- 除瞭@LoadBalanced之外,Ribbon還提供@RibbonClient註解。該註解可以為Ribbon客戶端聲明名稱和自定義配置。 name屬性可以設置客戶端的名稱, configuration屬性則會設置Ribbon相關的自定義配 類。
@Configuration public class RestTemplateConfig { /** * @return org.springframework.web.client.RestTemplate * @description 註入一個可以進行負載均衡的RestTemple用於服務問調用 * @author fengfan * @date 2022/5/18 14:43 */ @Bean @LoadBalanced public RestTemplate restTemplate(){ return new RestTemplate(); } }
yml配置負載均衡策略
# 配置的方式設置Ribbon的負載均衡策略 EUREKA-PROVIDER: # 設置服務提供方的應用名稱 ribbon: NFloadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule # 策略類(全路徑名)
代碼方式配置負載均衡策略
@Configuration public class RibbonConfig { /** * @return com.netflix.loadbalancer.IRule * @description 配置隨機負載策略 * @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); } }
客戶端調用實現
@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(); } }
測試
多次請求的服務端,端口隨機變化,證明配置成功。
到此這篇關於SpringCloud筆記(Hoxton)Netflix之Ribbon負載均衡示例代碼的文章就介紹到這瞭,更多相關SpringCloud Ribbon負載均衡內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- spring cloud 集成 ribbon負載均衡的實例代碼
- 淺談SpringCloud之Ribbon詳解
- Java Spring Cloud 負載均衡詳解
- Spring cloud alibaba之Ribbon負載均衡實現方案
- SpringCloud Eureka的使用教程