SpringCloud之loadbalancer負(fù)載均衡組件實(shí)戰(zhàn)詳解
SpringCloud之loadbalancer負(fù)載均衡組件
概述
在Spring Cloud 2020
版本后,默認(rèn)移除了對(duì)Netflix
的依賴,作為負(fù)載均衡組件的Ribbon
被棄用了,官方默認(rèn)推薦使用的是Loadbalancer
。
LoadBalancer簡(jiǎn)介
LoadBalancer
是Spring Cloud
官方提供的負(fù)載均衡組件,可用于替代Ribbon
。其使用方式與Ribbon
基本兼容,可以從Ribbon
進(jìn)行平滑過(guò)渡。
使用
依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-loadbalancer</artifactId> </dependency>
RestTemplate配置
@Configuration public class RestTemplateConfig { @Bean @ConfigurationProperties(prefix = "rest.template.config") public HttpComponentsClientHttpRequestFactory customHttpRequestFactory() { return new HttpComponentsClientHttpRequestFactory(); } @Bean @LoadBalanced public RestTemplate restTemplate() { return new RestTemplate(customHttpRequestFactory()); } }
服務(wù)提供者接口
@RestController @RequestMapping("/user") public class UserLoadBalancerController { @Autowired private RestTemplate restTemplate; @Value("${service-url.nacos-user-service}") private String userServiceUrl; @GetMapping("/{id}") public CommonResult getUser(@PathVariable Long id) { return restTemplate.getForObject(userServiceUrl + "/user/{1}", CommonResult.class, id); } }
服務(wù)實(shí)例緩存
LoadBalancer
為了提高性能,不會(huì)在每次請(qǐng)求時(shí)去獲取實(shí)例列表,而是將服務(wù)實(shí)例列表進(jìn)行了本地緩存。- 默認(rèn)的緩存時(shí)間為
35s
,為了減少服務(wù)不可用還會(huì)被選擇的可能性,我們可以進(jìn)行如下配置。
spring: cloud: loadbalancer: cache: # 負(fù)載均衡緩存配置 enabled: true # 開啟緩存 ttl: 5s # 設(shè)置緩存時(shí)間 capacity: 256 # 設(shè)置緩存大小
HTTP請(qǐng)求轉(zhuǎn)換
如果你想在每次遠(yuǎn)程調(diào)用中傳入自定義的請(qǐng)求頭的話,可以試試LoadBalancerRequestTransformer
,通過(guò)它可以對(duì)原始請(qǐng)求進(jìn)行一定的轉(zhuǎn)換。
- 首先我們需要配置好
LoadBalancerRequestTransformer
的Bean
實(shí)例,這里我們將ServiceInstance
的instanceId
放入到請(qǐng)求頭X-InstanceId
中;
@Configuration public class LoadBalancerConfig { @Bean public LoadBalancerRequestTransformer transformer() { return new LoadBalancerRequestTransformer() { @Override public HttpRequest transformRequest(HttpRequest request, ServiceInstance instance) { return new HttpRequestWrapper(request) { @Override public HttpHeaders getHeaders() { HttpHeaders headers = new HttpHeaders(); headers.putAll(super.getHeaders()); headers.add("X-InstanceId", instance.getInstanceId()); return headers; } }; } }; } }
在服務(wù)提供接口中打印請(qǐng)求頭
@RestController @RequestMapping("/user") public class UserController { @GetMapping("/{id}") public CommonResult<User> getUser(@PathVariable Long id) { User user = userService.getUser(id); LOGGER.info("根據(jù)id獲取用戶信息,用戶名稱為:{}", user.getUsername()); ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = servletRequestAttributes.getRequest(); String instanceId = request.getHeader("X-InstanceId"); if (StrUtil.isNotEmpty(instanceId)) { LOGGER.info("獲取到自定義請(qǐng)求頭:X-InstanceId={}", instanceId); } return new CommonResult<>(user); } }
到此這篇關(guān)于SpringCloud之loadbalancer負(fù)載均衡組件的文章就介紹到這了,更多相關(guān)SpringCloud loadbalancer負(fù)載均衡內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Springboot應(yīng)用gradle?Plugin示例詳解
這篇文章主要介紹了Springboot應(yīng)用gradle?Plugin詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04SpringCloud筆記(Hoxton)Netflix之Ribbon負(fù)載均衡示例代碼
這篇文章主要介紹了SpringCloud筆記HoxtonNetflix之Ribbon負(fù)載均衡,Ribbon是管理HTTP和TCP服務(wù)客戶端的負(fù)載均衡器,Ribbon具有一系列帶有名稱的客戶端(Named?Client),對(duì)SpringCloud?Ribbon負(fù)載均衡相關(guān)知識(shí)感興趣的朋友一起看看吧2022-06-06Java修改maven的默認(rèn)jdk版本為1.7的方法
這篇文章主要介紹了Java修改maven的默認(rèn)jdk版本為1.7的方法,需要的朋友可以參考下2018-02-02swagger注解@ApiModelProperty失效情況的解決
這篇文章主要介紹了swagger注解@ApiModelProperty失效情況的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06IDEA下SpringBoot指定配置文件啟動(dòng)項(xiàng)目的全過(guò)程
我們?cè)谑褂胹pringboot項(xiàng)目開發(fā)的時(shí)候,每次切換環(huán)境跑項(xiàng)目的時(shí)候,都得修改配置文件的數(shù)據(jù)庫(kù)地址,這樣來(lái)回修改感覺(jué)很麻煩,這篇文章主要給大家介紹了關(guān)于IDEA下SpringBoot指定配置文件啟動(dòng)項(xiàng)目的相關(guān)資料,需要的朋友可以參考下2023-06-06