API 网关是一个处于应用程序或服务(提供 REST API 接口服务)之前的系统,用来管理授权、访问控制和流量限制等,这样 REST API 接口服务就被 API 网关保护起来,对所有的调用者透明。因此,隐藏在 API 网关后面的业务系统就可以专注于创建和管理服务,而不用去处理这些策略性的基础设施。
1.修改gateway项目的pom,新增依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
2.在resources新增application.yml文件
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka/
instance:
instance-id: gateway-8090
prefer-ip-address: true #点击具体的微服务,是否显示ip
server:
port: 8090
spring:
application:
name: gateway
cloud:
gateway:
discovery:
locator:
enabled: true
routes: # 可以配置多个路由
- id: user_routh #payment_routh #路由的ID,没有固定规则但要求唯一,简易配合服务名
#uri: http://localhost:8001 #匹配后提供服务的路由地址
uri: lb://user #匹配后提供服务的路由地址,lb后跟提供服务的微服务的名,不要写错
predicates:
- Path=/user/** #断言,路径相匹配的进行路由
# 在该时间之后可以使用
- After=2020-09-28T17:07:03.043+08:00[Asia/Shanghai]
- id: order_routh #payment_routh #路由的ID,没有固定规则但要求唯一简易配合服务名
#uri: http://localhost:8001 #匹配后提供服务的路由地址
uri: lb://order #匹配后提供服务的路由地址,lb后跟提供服务的微服务的名,不要写错
predicates:
- Path=/order/** #断言,路径相匹配的进行路由
# 在该时间之后可以使用
- After=2020-09-28T17:07:03.043+08:00[Asia/Shanghai]
3.新增gateway项目的启动类
4.查看gateway是否注册到eureka中
5.测试gateway的网关
http://localhost:8090/order/getAllUser
http://localhost:8090/user/getAllUser
gateway的filter功能
实现自定义的filter只需要实现GlobalFilter, Ordered这两个接口,然后实现里面的方法即可。
新建MyFilter类 修改filter方法,此时拦截全部请求,且没有uname这个参数的请求都将拦截在外
重启gateway项目测试,浏览器输入http://localhost:8090/user/getAllUser,返回406证明被拦截,且控制台有打印拦截
加上uname参数再次测试http://localhost:8090/user/getAllUser?uname=9,请求成功,自定义Filter生效。
重写filter方法,不进行请求参数的校验
gateway的负载均衡
访问http://localhost:8090/user/testFeign,5次,user1项目收到了3次请求,user2项目收到了2次请求