spring cloud gateway如何獲取請求的真實地址
spring cloud gateway獲取請求的真實地址
在使用spring cloud gateway的時候,路由一般配置為服務(wù)名
例如 lb://BASE-API-WEB/xxx/bbb 路徑,我們無從知道,他真正路由到什么地方去了。
經(jīng)過查看源碼我發(fā)現(xiàn)了,
org.springframework.cloud.gateway.filter.LoadBalancerClientFilter
這個filter中 對lb請求進行了處理,轉(zhuǎn)換成真正的url地址。
核心方法如下
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
//lb下的url
URI url = (URI)exchange.getAttribute(ServerWebExchangeUtils.GATEWAY_REQUEST_URL_ATTR);
String schemePrefix = (String)exchange.getAttribute(ServerWebExchangeUtils.GATEWAY_SCHEME_PREFIX_ATTR);
if (url == null || !"lb".equals(url.getScheme()) && !"lb".equals(schemePrefix)) {
return chain.filter(exchange);
} else {
ServerWebExchangeUtils.addOriginalRequestUrl(exchange, url);
log.trace("LoadBalancerClientFilter url before: " + url);
ServiceInstance instance = this.loadBalancer.choose(url.getHost());
if (instance == null) {
throw new NotFoundException("Unable to find instance for " + url.getHost());
} else {
URI uri = exchange.getRequest().getURI();
String overrideScheme = null;
if (schemePrefix != null) {
overrideScheme = url.getScheme();
}
//真實的url
URI requestUrl = this.loadBalancer.reconstructURI(new LoadBalancerClientFilter.DelegatingServiceInstance(instance, overrideScheme), uri);
log.trace("LoadBalancerClientFilter url chosen: " + requestUrl);
exchange.getAttributes().put(ServerWebExchangeUtils.GATEWAY_REQUEST_URL_ATTR, requestUrl);
return chain.filter(exchange);
}
}
}其實,spring cloud gateway 已經(jīng)打印了日志,但是默認(rèn)的他是trace級別的,我們常用的日志級別是info級別,所有他不會打印,這就導(dǎo)致了我們在日志中看不到真實的url地址
以下是解決辦法
1.在配置文件中設(shè)置org.springframework.cloud.gateway.filter.LoadBalancerClientFilter的日志級別
logging.level.org.springframework.cloud.gateway.filter.LoadBalancerClientFilter=TRACE
注意 這里的配置一定要在
logging.level.org.springframework之后配置 不然會覆蓋
2.重寫LoadBalancerClientFilter 建立org.springframework.cloud.gateway.filter包 將 類重寫 spingboot默認(rèn)會從本項目中加載類,原先的類就被棄用了。
3.繼承LoadBalancerClientFilter 重寫filter方法,將日志級別改為info即可
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
URI url = exchange.getAttribute(ServerWebExchangeUtils.GATEWAY_REQUEST_URL_ATTR);
String schemePrefix = exchange.getAttribute(ServerWebExchangeUtils.GATEWAY_SCHEME_PREFIX_ATTR);
if (url == null || !"lb".equals(url.getScheme()) && !"lb".equals(schemePrefix)) {
return chain.filter(exchange);
} else {
ServerWebExchangeUtils.addOriginalRequestUrl(exchange, url);
ServiceInstance instance = this.loadBalancer.choose(url.getHost());
if (instance == null) {
throw new NotFoundException("Unable to find instance for " + url.getHost());
} else {
URI uri = exchange.getRequest().getURI();
String overrideScheme = null;
if (schemePrefix != null) {
overrideScheme = url.getScheme();
}
URI requestUrl = this.loadBalancer.reconstructURI(new LoadBalancerClientFilterBean.DelegatingServiceInstance(instance, overrideScheme), uri);
logger.info("before url = {} , url chosen = {} " ,url, requestUrl);
exchange.getAttributes().put(ServerWebExchangeUtils.GATEWAY_REQUEST_URL_ATTR, requestUrl);
return chain.filter(exchange);
}
}
}最終效果如下 :
![]()
spring cloud的GateWay網(wǎng)關(guān)中如何debug得到真實的路由地址
org.springframework.cloud.gateway.filter下面的


然后按下 Step over 就得到了 mergedUrl 這個變量,然后就可以看到真實請求的地址了

總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring?Boot?整合?Fisco?Bcos的案例分析(區(qū)塊鏈)
本篇文章介紹的?Spring?Boot?整合?Fisco?Bcos的案例,是在阿里云服務(wù)器上部署驗證的。大家可根據(jù)自己的電腦環(huán)境,對比該案例進行開發(fā)即可,具體案例代碼跟隨小編一起看看吧2022-01-01
SpringBoot集成JWT的工具類與攔截器實現(xiàn)方式
這篇文章主要介紹了SpringBoot集成JWT的工具類與攔截器實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01

