import lombok.extern.slf4j.Slf4j;
import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.core.Ordered;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;
/**
* 自定义全局过滤器,统计接口调用时间
*/
@Component
@Slf4j
public class MyGlobalFilter implements GlobalFilter, Ordered {
public static final String BEGIN_VISIT_TIME = "begin_visit_time";
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
//记录开始时间
exchange.getAttributes().put(BEGIN_VISIT_TIME, System.currentTimeMillis());
//返回统计结果
return chain.filter(exchange).then(Mono.fromRunnable(new Runnable() {
@Override
public void run() {
Long beginVisitTime = exchange.getAttribute(BEGIN_VISIT_TIME);
if (beginVisitTime != null) {
log.info("==============================================================");
log.info("访问接口主机:" + exchange.getRequest().getURI().getHost());
log.info("访问接口端口:" + exchange.getRequest().getURI().getPort());
log.info("访问接口URL:" + exchange.getRequest().getURI().getPath());
log.info("访问接口URL后面参数:" + exchange.getRequest().getURI().getRawQuery());
log.info("访问接口的时长:" + (System.currentTimeMillis() - beginVisitTime) + "毫秒");
log.info("==============================================================");
}
}
}));
}
/**
* 数字越小优先级越高
*
* @return
*/
@Override
public int getOrder() {
return 0;
}
}
gateway自定义全局过滤器,统计接口调用时间
最新推荐文章于 2024-04-05 13:20:29 发布