什么是网关
网关是系统对外的入口,提供路由请求、鉴权、监控、缓存、限流等功能
-
统⼀接⼊
智能路由
AB测试、灰度测试
负载均衡、容灾处理
⽇志埋点(类似Nignx⽇志) -
流量监控
限流处理
服务降级 -
安全防护
鉴权处理
监控
机器⽹络隔离
优点如下: -
安全 ,只有网关系统对外进行暴露,微服务可以隐藏在内网,通过防火墙保护。
-
易于监控。可以在网关收集监控数据并将其推送到外部系统进行分析。
-
易于认证。可以在网关上进行认证,然后再将请求转发到后端的微服务,而无须在每个微服务中进行认证。
-
减少了客户端与各个微服务之间的交互次数
-
易于统一鉴权。
主流的网关
zuul:是Netflix开源的微服务⽹关,和Eureka,Ribbon,Hystrix等组件配合使⽤,依赖组件⽐
较多,性能教差
kong: 由Mashape公司开源的,基于Nginx的API gateway
nginx+lua:是⼀个⾼性能的HTTP和反向代理服务器,lua是脚本语⾔,让Nginx执⾏Lua脚本,并且⾼并发、⾮阻塞的处理各种请求
- springcloud gateway: Spring公司专⻔开发的⽹关,替代zuul
项目中实战
第一步:创建一个gateway项目,引入相应的依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
第二步:配置相关信息
server:
port: 8888
spring:
application:
name: api-gateway
cloud:
gateway:
routes: #数组形式
- id: order-service #路由唯⼀标识
uri: http://127.0.0.1:9001 #想要转发到的地址
order: 1 #优先级,数字越⼩优先级越⾼
predicates: #断⾔ 配置哪个路径才转发
- Path=/order-server/**
filters: #过滤器,请求在传递过程中通过过
- StripPrefix=1 #去掉第⼀层前缀
#访问路径 http://localhost:8888/order-server/api/v1/video_order/list
#转发路径 http://localhost:8000/order-server/api/v1/video_order/list
#需要过滤器去掉前⾯第⼀层
第三步,编写启动类,run
@SpringBootApplication
public class GatewayApplication {
public static void main(String [] args){
SpringApplication.run(GatewayApplication.class,args);
}
}
使用网关前
使用网关后