前言
网关提供 API 全托管服务,丰富的 API 管理功能,辅助企业管理大规模的 API ,以降低管理成本和安全风险,包括协议适配、协议转发、安全策略( WAF )、防刷、流量、监控日志等功能。一般来说,网关对外暴露的 URL 或者接口信息,我们统称为路由信息。网关的核心是Filter 和 Filter Chain(过滤器链)
其中涉及到的一些专业术语如下:
路由(Route):网关的基本构建块。 它由 ID、目标 URI、断言集合和过滤器集合定义。 如果断言为真,则路由匹配成功。
断言(Predicate):Java 8 断言函数。 输入类型是 Spring 框架的ServerWebExchange。 可以匹配来自 HTTP 请求的任何内容,例如请求头或参数。
过滤器(Filter):使用特定工厂构建的 GatewayFilter 实例。 通过Filter可以在发送下游请求之前或之后修改请求和响应。
说再多不如写个案例,理解的快.
提供者服务用的的是我上一篇的,你们可以先看一写:Springcloud之openfeign远程调用
接下来我直接写网关的服务 注意Spring Cloud Gateway 启动容器目前只支持netty
1、maven依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</exclusion>
</exclusions>
</dependency>
2、yml配置(其中都有注释)
server:
port: 8994
spring:
application:
name: gateway-service
cloud:
gateway:
discovery:
locator:
enabled: true
# 服务名小写
lower-case-service-id: true
routes:
- id: nacos-producer1
# lb代表从注册中心获取服务,且已负载均衡方式转发
# 先用百度测试一下
# uri: http://baidu.com
uri: lb://cloud-provider1
predicates:
- Path=/cloud-provider1/**
# 加上StripPrefix=1,否则转发到后端服务时会带上testGateway前缀
filters:
- StripPrefix=1
# 不加入这个会报这个错Connection prematurely closed BEFORE response
httpclient:
pool:
max-idle-time: 10000
nacos:
discovery:
server-addr: localhost:8848
# 暴露监控端点
management:
endpoints:
web:
exposure:
include: '*'
endpoint:
health:
show-details: always
3、启动看结果
因为我这里是直接路由到我的cloud-proveider1服务
看我的提供者服务的controller:
@RestController
@RequestMapping("/testGateway")
public class TestGateWayController {
@GetMapping("/testG")
public String testGateWay(){
return "Hello,gateWay!";
}
}
新手上路,如有错误,请多多指教,谢谢。