springcloud-gateway中基本的请求日志打印
定义一个业务的过滤器public class AuthFilter implements GlobalFilter, Ordered {private static final Logger log = LoggerFactory.getLogger(AuthFilter.class);@Overridepublic Mono<Void> filter(ServerWebExchang
·
- 定义一个业务的过滤器
public class AuthFilter implements GlobalFilter, Ordered {
private static final Logger log = LoggerFactory.getLogger(AuthFilter.class);
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
exchange.getAttributes().put("start_time",System.currentTimeMillis());
....
@Override
public int getOrder() {
return NettyWriteResponseFilter.WRITE_RESPONSE_FILTER_ORDER-2;
}
- 定义一个日志过滤器
Route route =(Route) exchange.getAttributes().get(ServerWebExchangeUtils.GATEWAY_ROUTE_ATTR);
//路由ID
String routeId = route.getId();
Long startTime = exchange.getAttribute("start_time");
//获取耗时时长
final long duration = System.currentTimeMillis() - (Objects.isNull(startTime)?0L:startTime);
ServerHttpRequest request = exchange.getRequest();
ServerHttpResponse response = exchange.getResponse();
//请求路径
String requestUri = request.getURI().getPath();
//请求方法
String method = request.getMethodValue();
//请求的url参数
String param = MapUtil.join(request.getQueryParams(), "&", "=");
//响应码
int respStatusCode= Objects.requireNonNull(response.getStatusCode()).value();
//respStatusCode|Method|Host|Path|Query|Time|server_id
log.info("{}|{}|{}|{}|{}|{}ms|{}",respStatusCode,method, request.getURI().getHost(),
requestUri,param,duration,routeId);
return chain.filter(exchange.mutate().request(request).build());
}
@Override
public int getOrder() {
return NettyWriteResponseFilter.WRITE_RESPONSE_FILTER_ORDER-1;
}
- 打印样例

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐

所有评论(0)