学过微服务的人都知道,微服务的调用链是要先经过sprincloud gateway,即先经过网关那一层,然后在路由到相应的微服务,
由子模块的微服务在调用其他微服务,举个例子,一个微服务的请求调用链应该是这样的,一个接口的请求首先进来应该是到
服务网关,常见的微服务网关有zuul(已经停止维护,最大版本到2.0,2.0的版本比1.0性能要提升很多),gateway,现在alibabacloud
使用的网关为springcloud gateway,这个接口到了服务网关之后,就在服务网关这个配置文件里面配置了路由转发,鉴权、监控、限流等。
比如,可以在网关服务这一层做一次全局过滤器,这个全局过滤器类似于一个用户鉴权。
具体参考代码如下:
package net.xdclass.filter;
import org.apache.commons.lang3.StringUtils;
import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.core.Ordered;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;
import sun.net.www.http.HttpClient;
@Component
public class UserGlobalFilter implements GlobalFilter,Ordered {
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
String token = exchange.getRequest().getHeaders().getFirst("token");
if (StringUtils.isBlank(token)){
exchange.getResponse().setStatusCode(HttpStatus
.UNAUTHORIZED);
return exchange.getResponse().setComplete();
}
return chain.filter(exchange);
}
@Override
public int getOrder() {
return 0;
}
}