概念简介
Cloud全家桶中有个很重要的组件就是网关,在1.x版本中都是采用Zuul网关;但是在2.x版本中,zuul的升级一直跳票,SpringCloud最后自己研发了一个网关替代Zuul,那就是GateWay一句话gateway是元zuul1.x版的替代
Spring Cloud Gateway的目标提供统一的路由方式基于Filter链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流
三大核心概念
Route(路由)
路由是构建网关的基本模块,它由ID,目标URI,一些列的断言和或氯气组成,如果断言为true则匹配该路由
Predicate(断言)
参考的是Java8的java.util.function.Predicate,开发人员和一匹配HTTP请求中的所有内容(例如请求头或请求参数),**如果请求与断言相匹配则进行路由
Filter(过滤)
指的是Spring框架中的GatewayFilter的实例,使用过滤器,可以再请求路由前或者之后对请求进行修改
入门配置
- 引入jar包
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
注意!有个小坑,引入gateway时,需要排除springboot-web包,因为gateway内置用springWebFlux实现,不需要web包,否则会报错
- 整合配置
用到微服务,记得配好eureka client端到注册中心,在主启动类别忘加@EnableEurekaClient
网关配置
- 第一种方式 yml
spring:
application:
name: cloud-gateway
cloud:
gateway:
discovery:
locator:
enabled: true #开启从注册中心动态创建路由的功能,利用微服务名进行路由(拿取负载均衡的服务)
routes:
- id: payment_routh #路由器ID,没有固定规则但要求唯一,建议配合服务名
uri: lb://CLOUD-PAYMENT-SERVICE #匹配后提供服务的路由地址,lb为@LoadBalanced的缩写
predicates:
- Path=/payment/** #断言,路径相匹配的进行路由
- id: payment_routh2
uri: lb://CLOUD-PAYMENT-SERVICE
predicates:
- Path=/payment/serverInfo
- 第二种方式 代码注入bean
/**
* 配置了一个id为route-name的路由规则,
* 当访问地址为以下时,会自动转发地址
* @param routeLocatorBuilder
* @return
*/
@Bean
public RouteLocator routes(RouteLocatorBuilder routeLocatorBuilder) {
//路由器
RouteLocatorBuilder.Builder routes = routeLocatorBuilder.routes();
routes.route("path_route_1", r -> r.path("/payment/**").uri("http://localhost:8001")).build();
return routes.build();
}
个人推荐用yml方式,简单不麻烦
全局过滤器
有点像我们spring的过滤器,对请求进行一次筛选,我们可以再网关层做业务逻辑或日志等
@Component
@Slf4j
public class GateWayFilter implements GlobalFilter, Ordered {
@Override
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
String username = exchange.getRequest().getQueryParams().getFirst("username");
if(StringUtil.isNullOrEmpty(username)) {
log.info("非法用户");
return exchange.getResponse().setComplete();
}
return chain.filter(exchange);
}
@Override
public int getOrder() {
return 0;
}
}