1.Gateway是什么?
Gateway(网关)是一种用于构建微服务架构的核心组件,它充当了所有外部请求的入口,负责将请求路由到相应的微服务实例上。Gateway在微服务架构中起到了转发、负载均衡、安全认证、限流等多种功能。
具体来说,Gateway主要有以下几个作用:
-
路由转发:Gateway根据请求的URL路径将请求转发到相应的微服务实例上。通过配置路由规则,可以灵活地进行请求的转发和路由。
-
负载均衡:Gateway可以将请求分发到多个微服务实例上,实现负载均衡的功能。可以根据不同的负载均衡算法(如轮询、随机、加权等)来分发请求。
-
安全认证:Gateway可以对请求进行安全认证,确保只有经过认证的请求才能访问后端的微服务。可以通过配置认证规则,实现基于API密钥、JWT令牌、OAuth等方式的认证。
-
限流:Gateway可以对请求进行限流,防止恶意请求或者突发请求对后端服务造成过大的压力。可以通过配置限流规则,实现基于QPS、并发数、令牌桶等方式的限流。
-
监控和日志:Gateway可以记录请求和响应的详细信息,方便进行监控和日志分析。可以通过配置日志规则,实现请求日志的记录和分析。
-
缓存:Gateway可以对响应进行缓存,减少对后端服务的请求。可以根据配置的缓存规则,对响应进行缓存和缓存的管理。
总之,Gateway作为微服务架构的入口,起到了请求转发、负载均衡、安全认证、限流等多种功能。它可以提高系统的性能、安全性和可用性,同时也简化了微服务架构的开发和管理。
2.如何使用Gateway
Gateway网关的使用步骤如下:
- 创建SpringBoot工程gateway,引入网关依赖
- 编写启动类
- 编写基础配置和路由规则
- 启动网关服务进行测试
导入依赖:
#客户端依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
#网关依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
配置规则、路由:
spring:
cloud:
gateway:
routes: # 路由
- id: order-service-route
uri: lb://order-service
predicates: # 断言
- Path=/order/**,/orders/**
- id: product-service-route
uri: lb://product-service
predicates: # 断言
- Path=/product/**,/products/**
总结:
网关搭建步骤:
创建项目,引入nacos服务发现和gateway依赖
配置application.yml,包括服务基本信息、nacos地址、路由
路由配置包括:
路由id:路由的唯一标示
路由目标(uri):路由的目标地址,http代表固定地址,lb代表根据服务名负载均衡
路由断言(predicates):判断路由的规则,
路由过滤器(filters):对请求或响应做处理